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CROSS REFERENCED TO RELATED APPLICATION 

The present invention is related to the subject matter of the provisional United 
States Patent Application entitled, "Field-Ready Monocular Helmet Mounted Display 
Imagery Evaluation System," naming inventors Clarence E. Rash, Thomas H. Harding, 

15 Sheng-Jen Hsieh, Howard H. Beasley, John S. Martin, Ronald W. Reynolds, and Robert 
M. Dillard, filed October 11, 2000, Attorney Docket No. M-9582 VI. Applicants 
hereby claim the benefit under 35 U.S.C. § 119(e) of the foregoing-referenced 
provisional application. The contents of the foregoing-referenced provisional patent 
application are hereby incorporated by reference herein in its entirety. 

20 BACKGROUND OF THE INVENTION 
Field of the Invention 

The present application relates, in general, to methods and systems related to 
testing of display sighting systems. 

Description of the Related Art 

25 A display sighting system, in general, is a system which allows a pilot to 

integrate himself with a vehicle he is piloting. A display sighting system will 
generally have one or more unique features depending upon the environment in which 
the display sighting system is deployed. One feature which a display sighting system 
might have is the capability to allow a human pilot to see beyond the limitations of 

30 normal human vision (e.g., forward looking infrared radar (FLIR) systems, which use 
radar, image intensification, and infrared waves (which ordinarily cannot be seen by a 
human pilot) to construct and project a picture which a human pilot can see). Another 
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feature which a display sighting system might have is the integration of the display 
sighting system with weapons control of a helicopter (e.g., integrated such that the 
visual display of the display sighting system is integrated with the gun sights of the 
weapons on the helicopter). 

5 One example of a display sighting system is the Integrated Helmet and 

Display Sighting system (THADSS) of the U.S. Army's AH-64 Apache helicopter. 
(For ease of understanding, the present discussion will refer throughout to the 
IHADSS, but it will be recognized by those having ordinary skill in the art that the 
IHADSS is intended to be representative of the more general display sighting systems 
10 referenced above.) 

The IHADSS typically gathers information related to the terrain and 
environment in which the AH-64 is operating by using cameras and/or sensors affixed 
to the AH-64. Thereafter, the IHADSS processes the gathered information into a 
form which can be seen by a human pilot, and thereafter projects the gathered and 

1 5 processed information via an assortment of electronic and optical apparatuses 
(described in more detail, below) into a human pilot's field of view. In many 
instances, a pilot of an AH-64 is actually flying the helicopter or targeting the 
helicopter's weapons systems on the basis of what is displayed by the IHADSS. 
Accordingly, it is imperative that each individual IHADSS project a clear and 

20 accurate depiction of the terrains and/or environments captured by its associated 

cameras and sensors. Unfortunately, the integration of each individual IHADSS with 
the systems and subsystems of AH-64 helicopters in which each individual IHADSS 
is deployed makes it difficult to ensure that each individual IHADSS is projecting a 
clear, accurate, and quality depiction of the terrains and/or environments captured by 

25 its associated cameras and sensors. This difficulty is due in large part to a lack of 
effective methods and systems for the assessment of the accuracy and quality of 
IHADSS imagery in a field environment. 

At present, when an IHADSS is deployed in a field environment, the accuracy 
and quality of the deployed IHADSS imagery is determined on a subjective basis by 
30 each pilot viewing the IHADSS' display device. Those having ordinary skill in the 
art will recognize that such a methodology is suboptimal for several reasons. One 
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reason why such methodology is suboptimal arises from interaction of the gradual 
degradation of the IHADSS with the adaptability of the human visual system. Those 
having ordinary skill in the art will recognize that over time it is common for the 
visual displays of IHADSS to gradually degrade and become distorted for various 
reasons (e.g., aging of the electronics, routine wear and tear, shock and vibration, 
etc.). It has been found by the inventors named herein ("the inventors") that in 
practice, an IHADSS display can be substantially degraded without such degradation 
being detectable by the human pilot, because insofar as each IHADSS is typically 
tuned by a specific human pilot, and insofar as the degradation of the IHADSS over 
time is often gradual, the adaptability of the human visual system often tricks the 
human pilot into thinking IHADSS display is accurate and/or acceptable when in fact 
it is substantially inaccurate and/or unacceptable. Another reason why the current 
methodology is suboptimal arises from the lack of accuracy and/or reproducibility 
generally associated with subjective approaches. 

In light of the foregoing, it is clear that a need exists for a method and system 
which will practicably allow the objective assessment of the functioning of individual 
IHADSSs used by pilots in the field. Unfortunately, those skilled in the art will 
recognize that the objective testing of display sighting systems such as the IHADSS is 
generally a very involved process which at present is generally only done in the 
laboratory environment via use of a series of well defined discrete operations 
performed with separate items of test equipment. Those skilled in the art will 
recognize that, in general, the testing done in the laboratory environment is not 
adaptable to operation in the field. 

One reason why the testing done in the laboratory environment is generally 
not adaptable to operation in the field is that once IHADSS have been deployed, 
operators are prohibited from changing the hardware and/or software within the 
IHADSS without a specific Army requirement and without cooperation from the 
IHADSS manufacturer. As a consequence of this, the sophisticated hardware and 
software often used in the laboratory environment cannot be used to test IHADSS in 
the field, since what can be used consists of only what is built-in to the IHADSS. 
Another reason why testing done in the laboratory environment is generally not 
adaptable to operation in the field is that the delicate testing equipment used in the lab 
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is generally not appropriate for field testing. Yet another reason why testing done in 
the laboratory environment is generally not adaptable to operation in the field is that it 
is generally not practicable to deploy the large and bulky testing equipment used in 
the lab into the field environment. 

In light of the fact that there is at present no practicable way to adapt IHADSS 
testing done in the laboratory environment to field environments, it is therefore 
apparent that the need exists for a method and system which will practicably allow the 
objective assessment of the functioning of individual IHADSSs in a field 
environment. 

SUMMARY OF THE INVENTION 

The inventors have devised a method and system which will practicably allow 
the objective assessment of the functioning of individual display sighting systems, 
such as IHADSSs, in a field environment. 

In one implementation, a method includes but is not limited to capturing an 
image actually displayed via a display sighting system; computing at least one 
difference between the captured image and a recalled representation of the image 
theoretically displayed via the display sighting system; and presenting the computed 
at least one difference via a visual display device. In various implementations, 
circuitry is used to effect the foregoing-described method; the circuitry can be 
virtually any combination of hardware, software, and/or firmware configured to effect 
the foregoing-described method depending upon the design choices of the system 
designer. 

The foregoing is a summary and thus contains, by necessity, simplifications, 
generalizations and omissions of detail; consequently, those skilled in the art will 
appreciate that the summary is illustrative only and is not intended to be in any way 
limiting . Other aspects, inventive features, and advantages of this patent application 
will become apparent in the non-limiting detailed description set forth below. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention may be better understood, and its numerous objects, 
features, and advantages made apparent to those skilled in the art by referencing the 
accompanying drawings. 

5 Figure 1 illustrates a perspective view of pilot 100 wearing IHU 102 

Figure 2 depicts a perspective view of HDU 104 in isolation. 

Figures 3 A, 3B, 3C, 3D and 3E show three different perspective views of 
positioning device 300, which is an apparatus which allows HDU 104 in holding 
fixture 390 to be moved between a first position (see Figure 3D) and a second 
10 position (see Figure 3E) such that an image projected by HDU 104 onto combiner 106 
can be respectively captured by narrow-angle camera 306 and wide-angle camera 308 
(see Figures 3D and 3E). 

Figure 4 illustrates test pattern 400 which comes built-in with the IHADSS 
produced by Honeywell, Inc. 

15 Figure 5 shows a high-level logic flowchart. 

Figure 6A depicts alternate implementations of the high-level logic flowchart 
depicted in Figure 5. 

Figures 6B and 6C illustrate pictographic representations of the methodology 
used by one implementation to compute the centering difference of method step 602 
20 and the angular difference of method step 600. 

Figure 7 illustrates alternate implementations of the high-level logic flowchart 
depicted in Figure 6A. 

Figure 8 shows alternate implementations of the high-level logic flowchart 
depicted in Figure 5. 

25 Figure 9 depicts alternate implementations of the high-level logic flowchart 

depicted in Figure 8. 
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Figure 10 illustrates a pictorial representation of a conventional data 
processing system in which illustrative embodiments of the devices and/or processes 
described herein may be implemented. 

Figure Al shows the IHADSS. 

5 Figure A2 depicts The IHADSS HDU. 

Figure A3 illustrates display size. 

Figure A4 shows the built-in test pattern of the IHADSS HMD. 

Figure A5 depicts a configuration in which two cameras face the HMD from 
different directions. 

1 0 Figure A6 illustrates a revised design of that depicted in Figure A5. 

Figure A7 shows locations of sensors in proposed HMD fixture design. 

Figure A8 depicts a typical DAQCard-DIO-24 configuration. 

Figure A9 illustrates how the HMD hardware fixtures, sensors, I/O cable, and 
DAQCard-DIO-24 card are integrated. 

15 Figure A10 shows initial display screen, switches open. 

Figure All depicts a display screen, continue button, switches open. 

Figure A12 illustrates display screen, switches 1 and 2 pressed. 
Figure A13 shows display screen, image capture module activated. 

Figure A14 depicts a screenshot of the newly designed image capture interface 
20 module, showing an image of the HMD test pattern taken using the wide-angle 
camera. 

Figure A15 illustrates screenshots of parameter setting display screens. 
Figure A16 shows an original image/test pattern. 
Figure A17 depicts the image of Figure A16 after binary processing. 
-6- 
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Figure Bl illustrates the MU of the AH-64 fflADSS. 
Figure B2 shows the EHADSS HDU. 
Figure B3 depicts the display size. 

Figure B4 shows a snapshot of the test pattern captured from the IHADSS 

HMD. 

Figure B5 illustrates a flow chart for HMD prototype tester operation. 

Figure B6 depicts an experimental setup. 

Figure B7 shows sampling locations on a test pattern. 

Figure B8 illustrates a plot of photometer and CCD camera data. 

Figure B9 shows a set up for test pattern measurement. 

Figure BIO illustrates a test pattern design based on measurement results. 

Figure Bl 1 displays a replicated test pattern image. 

Figure B 12 shows the measurement of luminance of the center lines. 

Figure B 13 illustrates center lines measurement with varied focus. 

Figure B 14 displays a designed test pattern with focusi on the center lines. 

Figure B 15 shows modules involved in the prototype. 

Figure B16 shows the opening screen for the image capture module. 

Figure B17 depicts an image capture component. 

Figure B 18 illustrates an image processing component. 

Figure B19 shows an image analysis and interpretation module. 

Figure B20(a-d) depicts tilted test pattern binary images from image analysis 
module. 
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Figure B21 illustrates overall testing results of an HMD. 

Figure B22 shows tilted test pattern before and after Sober edge detection. 

Figure B23 depicts investigation of CCD image capture arrangement. 

Figure B24 illustrates a preliminary computer aided design (CAD) concept of 
5 a hardware prototype design. 

The use of the same reference symbols in different drawings indicates similar 
or identical items. 

DESCRIPTION OF THE PREFERRED EMBODIMENT(S) 

As described above, the U.S. Army's AH-64 Apache helicopter incorporates a 
10 monocular helmet mounted display (HMD) known as the Integrated Helmet and 
Display Sighting System (IHADSS). The IHADSS consists of various electronic 
components and a helmet/display system called the Integrated Helmet Unit (IHU). 

With reference to the figures, and in particular with reference now to Figure 1, 
shown is a perspective view of pilot 100 wearing IHU 102. Depicted is that IHU 102 

15 includes Helmet Display Unit (HDU) 104. HDU 104 serves as an optical relay device 
which conveys an image formed on a mini-CRT through a series of lenses (the mini- 
CRT and lenses are internal to HDU 104, and hence are not shown explicitly), off 
beamsplitter (combiner) 106, an into pilot 100' s right eye. Combiner 106 is so named 
in that its construction allows pilot 100 to see whatever image is projected from HDU 

20 104 superimposed, or combined with, whatever pilot 100 can see through combiner 
106; in effect, combiner 106 functions as a mirror with respect to the projection of the 
mini-CRT within HDU 104, and a lens with respect to allowing pilot 100 to see what 
is in front of him. That is, if one looks closely at Figure 1, one can see that pilot 100' s 
eye is visible through combiner 106, which means that pilot can see through combiner 

25 106. Consequently, what pilot 100 sees will be a combination of the projection of 
HDU 104 and what appears in front of pilot 100 (i.e., whatever pilot 100 can see via 
the lens function of combiner 106). 
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Referring now to Figure 2, shown is a perspective view of HDU 104 in 
isolation. 

Referring now to Figures 3A, 3B, and 3C, shown are three different 
perspective views of positioning device 300, which is an apparatus which allows 
5 HDU 104 in holding fixture 390 to be moved between a first position (see Figure 3D) 
and a second position (see Figure 3E) such that an image projected by HDU 104 onto 
combiner 106 can be respectively captured by narrow-angle camera 306 and wide- 
angle camera 308 (see Figures 3D and 3E). Further shown in Figures 3B and 3C is 
spring 350 which has first end 358 in stationary attachment with camera table 360 and 

10 second end 362 in mobile attachment t-shaped-end of lever 352. Lever 352 is shown 
attached to pivot pole 356. A second end (not shown) of lever 352 is pivotably 
attached to the underside of holding fixture 390 such that when holding fixture 390 is 
moved back and forth along guide rails 364 and 366, the second end of lever 
pivotably attached to the underside of holding fixture 390 will pivot such that t- 

15 shaped-end of lever 352 will pivot about pivot pole 356. 

In operation, when HDU 104 in holding fixture 390 is moved between a first 
position (see Figure 3D) and a second position (see Figure 3E) by sliding along guide 
rails 364 and 366, lever 352 pivots about pivot pole 356 and second end 362 of spring 
350 slides along t-shaped-end of lever 352 and is such that when holding fixture 390 
20 is in either the first or second position, spring 350 applies pressure through t-shaped- 
end of lever 352 such that pressure is applied through second end of lever 352 to 
holding fixture 390 such that holding fixture 390, and hence HDU 104, is held in 
either that first or second position. 

With reference now to Figures 3D and 3E, shown are two different perspective 
25 views of HDU 104 in positioning device 300, which is an apparatus which allows 
HDU 104 to be moved between a first position and a second position such that an 
image projected by HDU 104 onto combiner 106 can be respectively captured by 
narrow-angle camera 306 and wide-angle camera 308. 

Referring now to Figure 4, shown is test pattern 400 which comes built-in with 
30 the IHADSS produced by Honeywell, Inc. The original main purpose of test pattern 
400 was to provide Honeywell field engineers with something consistent to view on 

-9- 

689433 vl 



Attorney Docket No.: M-9582 US 



the IHADSS when the IHADSS was first deployed to the field. The original 
secondary purpose of test pattern 400 was to provide pilots with a fixed pattern which 
the pilots could use to subjectively optimize their display. Consequently, test pattern 
400 is substantially always available on virtually every IHADSS systems. (It is to be 
5 understood that although the test pattern of the IHADSS is discussed herein for sake 
of simplicity, the discussion is meant to be representative of test patterns utilized with 
display sighting systems, and such test patterns can come preloaded from the factory 
or may be loaded after the fact, and such test patterns may be multiple in number.) 

Depicted is that in one embodiment, test pattern 400 is treated as having two 
10 portions: wide-angle portion 402, which is co-extensive with test pattern 400 itself, 
and narrow-angle portion 404, which is denoted as the small rectangular portion 
substantially between the gray-scale strips in Figure 4. Wide-angle portion 402 and 
narrow-angle portion 404 are so named because in one embodiment wide-angle 
camera 308 and narrow-angle camera 306 are used to respectively capture such 
15 portions. 

With reference now to Figure 5, shown is a high-level logic flowchart. 
Method step 500 depicts the start of the process. Method step 502 illustrates 
capturing an image of IHADSS test pattern 400. Method step 504 shows computing 
at least one difference between the captured image of IHADSS test pattern 400 and a 

20 recalled representation of the image of IHADSS test pattern 400 theoretically 

displayed via the display sighting system; that is, there is stored in memory (e.g., 
computer memory) a representation of how the image of IHADSS test pattern 400 
would or should appear if the IHADSS is both functioning correctly and set up 
properly (e.g., by a pilot), and it is such a representation that is recalled. Method step 

25 506 shows presenting the computed at least one difference via a visual display device 
(e.g., via a portable computer system display). Method step 508 shows the end of the 
process. 

Referring now to Figure 6A, shown are alternate implementations of the high- 
level logic flowchart depicted in Figure 5. Method step 600 illustrates that in one 
30 implementation method step 504 includes computing at least one angular difference 
between an angular orientation of the captured image and the recalled representation 
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of the image theoretically displayed via the display sighting system. Method step 602 
shows that in one implementation method step 504 includes computing at least one 
centering difference between a center point of the captured image and the recalled 
representation of the image theoretically displayed via the display sighting system. 
5 Method step 604 depicts that in one implementation method step 504 includes 
computing at least one focus difference between an optical power of the captured 
image and the recalled representation of the image theoretically displayed via the 
display sighting system. The remaining method steps of the flowchart depicted in 
Figure 6 function substantially as shown and described herein. 

10 In one instance, the implementations of Figure 6A are carried out by capturing 

narrow-angle portion 404 of IHADSS test pattern 400 with narrow-angle camera 306, 
converting the captured narrow-angle portion to "binary form," and recalling a 
representation of what narrow-angle portion 404 of IHADSS test pattern 400 should 
look like if the IHADSS system were functioning substantially optimally. As used 

15 herein converting to "binary form" means creating a two-color image, where all 

captured image pixels having a number below a calculated threshold are set to gray 
level 0 (pure black) and all captured image pixels above a calculated threshold value 
are set to gray level 255 (pure white in a system with 0-255 gray levels). Specific 
examples of the foregoing described conversion to binary images appear in Specific 

20 Implementation A, Design of Interface and Algorithms for an Image Quality Tester 
, (see, especially Figures A16 and A17 and the discussion of same), and Specific 
Implementation B, Preliminary Design of an Image Quality Tester for Helmet- 
Mounted Displays. 

Referring now to Figures 6B and 6C, shown are pictographic representations 
25 of the methodology used by one implementation to compute the centering difference 
of method step 602 and the angular difference of method step 600. Figure 6B shows 
that, in one implementation of method step 602, the center point of the actual image 
captured (point "B") can be compared with where the center point should be if the 
IHADSS were functioning substantially optimally (point "A," which is obtained from 
30 the recalled representation of the image theoretically displayed via the display 

sighting system), and the resulting x-y displacement used to compute the distance 
difference, d, between actual and theoretical center point locations (the x-y units can 
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be any unit of length, but in one embodiment the x-y units are millimeters). With 
reference to Figure 6C, shown is that a right triangle drawing on the x-y position 
relative to points A and B can be used in combination with a point chosen to be on the 
"vertical" line of captured narrow-angle portion 404 of IHADSS test pattern 400 in 
5 order to calculate 6 (theta) as the orientation difference between the captured image 
orientation and the theoretically ideal images. Specific examples of the foregoing 
appear in Specific Implementation A, Design of Interface and Algorithms for an 
Image Quality Tester (especially in the Algorithm Design section, subsection C, 
wherein various approaches for identifying the center point and identifying test 
10 pattern orientation and displacement are described), and in Specific Implementation 
B, Preliminary Design of an Image Quality Tester for Helmet-Mounted Displays. 

With respect to computing the focus difference of method step 604, note that 
narrow-angle portion 404 of IHADSS test pattern 400, subsequent to being converted 
to binary form, has four bright white vertical lines bounded by dark black regions. It 

15 has been discovered by the inventors that measurement of luminance differences 
between the alternating bright white and dark black regions can be utilized to 
determine focus. For example, in Specific Implementation B, Preliminary Design of 
an Image Quality Tester for Helmet-Mounted Displays, Figure B 12 and its supporting 
text shows how luminance measurements appear when narrow-angle portion 404 of 

20 IHADSS test pattern 400 is in focus. In contrast, Figure B13 and its supporting text 
shows several examples of how luminance measurements appear when narrow-angle 
portion 404 of IHADSS test pattern 400 is out of focus. Consequently, in one 
implementation, the focus difference of method step 604 can be calculated based on 
how far the measured luminances of the alternating black and white lines of the binary 

25 image form of captured narrow-angle portion 404 of IHADSS test pattern 400 varies 
from the ideal (e.g., such as that appearing in Figure B12). 

With reference now to Figure 7, depicted are alternate implementations of the 
high-level logic flowchart depicted in Figure 6A. Method step 700 illustrates that in 
one implementation method step 506 includes presenting (e.g., via a visual display 
30 device of a portable computer) the at least one angular difference between an angular 
orientation of the captured image and the recalled representation of the image 
theoretically displayed via the display sighting system (e.g., the computed quantity of 
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method step 600). Method step 702 shows that in one implementation method step 
506 includes presenting (e.g., via a visual display device of a portable computer 
system) the at least one centering difference between a center point of the captured 
image and the recalled representation of the image theoretically displayed via the 
display sighting system (e.g., the computed quantity of method step 602). Method step 
704 depicts that in one implementation method step 506 includes presenting (e.g., via 
a visual display device of a portable computer system) the at least one focus 
difference between an optical power of the captured image and the recalled 
representation of the image theoretically displayed via the display sighting system 
(e.g., the computed quantity of method step 604). The remaining method steps of the 
flowchart depicted in Figure 7 function substantially as shown and described herein. 

Referring now to Figure 8, shown are alternate implementations of the high- 
level logic flowchart depicted in Figure 5. Method step 800 illustrates that in one 
implementation method step 504 includes computing at least one gray-shades- 
displayed difference between gray shades of the captured image and gray shades of 
the recalled representation of the image theoretically displayed via the display 
sighting system. Method step 802 shows that in one implementation method step 504 
includes computing at least one field-of-view difference indicated by a difference 
between a boundary location of the captured image and the recalled representation of 
the image theoretically displayed via the display sighting system. Method step 804 
shows that in one implementation method step 504 includes computing at least one 
image quality figure of merit indicated by a difference between brightness, contrast, 
and gray level of a captured image and the recalled representation of the image 
theoretically displayed via the display sighting system. The remaining method steps 
of the flowchart depicted in Figure 8 function substantially as shown and described 
herein. 

In one instance, one implementation of method step 800 of Figure 8 is carried 
out by capturing wide-angle portion 402 of IHADSS test pattern 400 with wide-angle 
camera 308, and thereafter recalling a representation of what wide-angle portion 402 
of IHADSS test pattern 400 should look like if the IHADSS system were functioning 
substantially optimally. The underlying methodology of method step 800 is based on 
an agreed upon luminance difference which is expressed as square root of two 
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differences in gray or luminance levels (this standard is a de facto standard which has 
arisen over the years by course of use). Thus, in one embodiment, the captured image 
is iteratively moved through and a count is kept as to how many square root of two 
gray scale "jumps," or discontinuities (which occur in test pattern 400 at the 
boundaries of the varying gray bars - see Figure 4), are detected. This number of 
discontinuities are then compared against what is expected if the IHADSS is operating 
correctly. Specific examples of the foregoing appear in Specific Implementation A: 
Design of Interface and Algorithms for an Image Quality Tester (e.g., Figure A15 and 
Algorithm Design section, subsection D, which discusses identifying the number of 
gray shades within a test pattern), and Specific Implementation B: Preliminary Design 
of An Image Quality Tester for Helmet-Mounted displays. 

In one instance, one implementation of method step 802 of Figure 8 is carried 
out by capturing wide-angle portion 402 of IHADSS test pattern 400 with wide-angle 
camera 308, and thereafter recalling a representation of what wide-angle portion 402 
of IHADSS test pattern 400 should look like if the IHADSS system were functioning 
substantially optimally. The underlying methodology of method step 802 is based on 
a recognition that when the IHADSS is functioning properly, and the pilot has not 
improperly adjusted display size, the boundaries of the test pattern should be just on 
the edge of the field of view of the display. Accordingly, if the boundaries are found 
at the wrong location, or if the boundaries are not detected at all, it is known that there 
is a malfunction of some sort. Specific examples of the foregoing appear in Specific 
Implementation A: Design of Interface and Algorithms for an Image Quality Tester 
(see e.g., Figure A15 and Algorithm Design section, subsection E, which discusses 
identifying boundary lines), and Specific Implementation B, Preliminary Design of 
An Image Quality Tester for Helmet-Mounted displays. 

In one instance, one implementation of method step 804 of Figure 8 is carried 
out by capturing wide-angle portion 402 of IHADSS test pattern 400 with wide-angle 
camera 308, and thereafter recalling a representation of what wide-angle portion 402 
of IHADSS test pattern 400 should look like if the IHADSS system were functioning 
substantially optimally. The underlying methodology is based on a recognition that 
when the IHADSS is functioning properly, and the pilot has brightness and contrast 
levels of the IHADSS set within acceptable tolerances, the average gray level detected 
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should be within certain defined tolerances relative to average gray level drawn on 
how the image should appear if the IHADSS is functioning in a substantially optimal 
mode. Accordingly, if the detected gray levels are substantially outside the bounds of 
the defined tolerances, it is known either that the system is malfunctioning or that the 
pilot has either the brightness and/or contrast settings wrong. Specific examples of the 
foregoing appear in Specific Implementation A: Design of Interface and Algorithms 
for an Image Quality Tester (e.g., Figure A15 and Algorithm Design section, 
subsection E, which discusses identifying the contrast, brightness, and gray level 
relationship), and Specific Implementation B: Preliminary Design of An Image 
Quality Tester for Helmet-Mounted displays. 

With reference now to Figure 9, depicted are alternate implementations of the 
high-level logic flowchart depicted in Figure 8. Method step 900 illustrates that in 
one implementation method step 506 includes presenting (e.g., via a visual display 
device of a portable computer system) the at least one gray-shades-displayed 
difference between gray shades of the captured image and gray shades of the recalled 
representation of the image theoretically displayed via the display sighting system 
(e.g., the computed quantity of method step 800). Method step 902 shows that in one 
implementation method step 506 includes presenting (e.g., via a visual display device 
of a portable computer system) the at least one field-of-view difference indicated by a 
difference between a boundary location of the captured image and the recalled 
representation of the image theoretically displayed via the display sighting system 
(e.g., the computed quantity of method step 802). Method step 904 shows that in one 
implementation method step 506 includes presenting (e.g., via a visual display device 
of a portable computer system) the at least one image quality figure of merit indicated 
by a difference between brightness, contrast, and gray level of a captured image and 
the recalled representation of the image theoretically displayed via the display 
sighting system (e.g., the computed quantity of method step 804). The remaining 
method steps of the flowchart depicted in Figure 9 function substantially as shown 
and described herein. 

Those skilled in the art will recognize that the state of the art has progressed to 
the point where there is little distinction left between hardware and software 
implementations of aspects of systems; the use of hardware or software is generally 
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(but not always, in that in certain contexts the choice between hardware and software 
can become significant) a design choice representing cost versus efficiency tradeoffs. 
The foregoing detailed description has set forth various embodiments of the devices 
and/or processes via the use of block diagrams, flowcharts, and examples. Insofar as 
5 such block diagrams, flowcharts, and examples contain one or more functions and/or 
operations, it will be understood as notorious by those within the art that each 
function and/or operation within such block diagrams, flowcharts, or examples can be 
implemented, individually and/or collectively, by a wide range of hardware, software, 
firmware, or any combination thereof. In one embodiment, the present invention may 

10 be implemented via Application Specific Integrated Circuits (ASICs). However, 

those skilled in the art will recognize that the embodiments disclosed herein, in whole 
or in part, can be equivalently implemented in standard Integrated Circuits, as a 
computer program running on a computer, as a program running on a processor, as 
firmware, or as virtually any combination thereof and that designing the circuitry 

15 and/or writing the code for the software or firmware would be well within the skill of 
one of ordinary skill in the art in light of this disclosure. In addition, those skilled in 
the art will appreciate that the mechanisms of the present invention are capable of 
being distributed as a program product in a variety of forms, and that an illustrative 
embodiment of the present invention applies equally regardless of the particular type 

20 of signal bearing media used to actually carry out the distribution. Examples of a 
signal bearing media include but are not limited to the following: recordable type 
media such as floppy disks, hard disk drives, CD ROMs, digital tape, and 
transmission type media such as digital and analogue communication links using 
TDM or IP based communication links (e.g., packet links). 

25 In a general sense, those skilled in the art will recognize that the various 

embodiments described herein which can be implemented, individually and/or 
collectively, by a wide range of hardware, software, firmware, or any combination 
thereof can be viewed as being composed of various types of "electrical circuitry." 
Consequently, as used herein "electrical circuitry" includes but is not limited to 

30 electrical circuitry having at least one discrete electrical circuit, electrical circuitry 
having at least one integrated circuit, electrical circuitry having at least one 
application specific integrated circuit, electrical circuitry forming a general purpose 
computing device configurable by a computer program (e.g., a general purpose 
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computer configurable by a computer program or a microprocessor configurable by a 
computer program), electrical circuitry forming a memory device (e.g., any and all 
forms of random access memory), and electrical circuitry forming a communications 
device (e.g., a modem, communications switch, or optical-electrical equipment). 

Those skilled in the art will recognize that it is common within the art to 
describe devices and/or processes in the fashion set forth above, and thereafter use 
standard engineering practices to integrate such described devices and/or processes 
into data processing systems. That is, the devices and/or processes described above 
can be integrated into data processing system via a reasonable amount of 
experimentation. Figures 7 and 8 show an example representation of a data 
processing system into which the described devices and/or processes may be 
implemented with a reasonable amount of experimentation. 

With reference now to Figure 10, depicted a pictorial representation of a 
conventional data processing system in which illustrative embodiments of the devices 
and/or processes described herein may be implemented. It should be noted that a 
graphical user interface systems (e.g., Microsoft Windows 98 or Microsoft Windows 
NT operating systems) and methods can be utilized with the data processing system 
depicted in Figure 10. Data processing system 1020 is depicted which includes 
system unit housing 1022, video display device 1024, keyboard 1026, mouse 1028, 
and microphone 1048. Data processing system 1020 may be implemented utilizing 
any suitable computer such as a DELL portable computer system, a product of Dell 
Computer Corporation, located in Round Rock, Texas; Dell is a trademark of Dell 
Computer Corporation. 
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EXAMPLE IMPLEMENTATION A 

(The following is similar to Hsieh, et al., "Design of Interface and Algorithms for an 
Image Quality Tester," USAARL Report No. 2000-26 (August, 2000), the content of 
which is hereby incorporated by reference in its entirety.) 

5 USAARL REPORT NO. 2000-26 



10 
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Introduction 



The U.S. Army's AH-64 Apache attack helicopter incorporates a monocular 
helmet mounted display (HMD) known as the Integrated Helmet and Display Sighting 
5 System (IHADSS). The IHADSS consists of various electronic components and a 
helmet/display system called the Integrated Helmet Unit (IHU). The IHU (Figure Al) 
includes a helmet, visor housings with visors, miniature cathode ray tube (CRT), and 
helmet display unit (HDU). The HDU (Figure Al) serves as an optical relay device 
which conveys the image formed on the CRT through a series of lenses, off a 
10 beamsplitter (called a combiner), and into the aviator's right eye. The CRT is 1 inch 
in diameter and uses a P-43 phosphor. The combiner is a multilayer dichroic filter 
which is maximized for reflectance at the peak emission of the P-43 phosphor. 



Currently, there is no existing objective system for validation in the field of 
the quality of the imagery presented via the IHADSS. To maintain system integrity 
20 and readiness, and to provide pilots with validated pilotage, navigation, and fire 
control imagery, there is a need to develop an image quality testing tool for the 
IHADSS. This tester could be used as a validation tool to verify settings for regular 
flight missions and for preventive maintenance tasks. A preliminary tester design for 
the AH-64's IHADSS HMD was proposed and reported in Hsieh et al. (1999). 

25 

The objectives of the work reported here were to design and integrate 
communications interface and software procedure components for the proposed 
IHADSS HMD image tester. This is a continuation of the previous effort. The 
function of the communications interface is to sense (i.e., calculate) the positions of 

30 the camera and HMD based on the status of limit switches attached to a fixture used 
to mount the camera and HMD. This information then is converted to an eight-bit 
binary value using a digital I/O (input/output) data acquisition card. This discrete 
value is used by a custom developed software program as an indicator of the status of 
the hardware. Image capture routines then are activated to capture the test pattern 

35 generated by the HMD under test. The program applies image processing procedures 
to the images. In addition, image processing algorithms that can extract image 
features from HMD imagery and analyze them relative to the design specifications are 
proposed. These developments will allow automated evaluation of the image quality 
of an HMD. 

40 FUNCTIONALITY AND OPERATING PROCESS 

The IHADSS HMD has a 30-degree vertical by 40-degree horizontal field of 
view (FOV). Corner obscuration is permissible and symmetrical, as illustrated in 
Figure A3. The built-in test pattern (Figure A4) of the IHADSS HMD is used as the 
45 inspection specification on which the tester will be based. The test pattern shows 

strips of gray opposed along a centering line. Each strip contains a minimum of 8 to 
10 shades of gray, depending on the contrast ratio. Adjacent shades have a square 



15 



See 

Figure Al. The IHADSS. 



See 

Figure A2. The IHADSS HDU. 
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root of 2 differential of luminance. For a more detailed discussion of the HMD test 
pattern features, see the Honeywell, Inc., study guide (1985) and Harding et al. 
(1995). For testing this test pattern, the inspection features of the image quality tester 
prototype include: (1) four center lines, (2) one horizontal line, (3) 8 to 10 gray 
5 shades, (4) boundary lines, and (5) illumination and focus. 

See 

Figure A3. Display size. 

10 See 

Figure A4. MADSS built-in test pattern. 



The operation procedures of the proposed HMD tester are as follows: 

15 

(1) The pilot adjusts the HMD settings; 

(2) The crew chief inserts the HMD into a holding fixture; 

(3) The system examines the center and horizontal line features of the test pattern 
using a narrow-angle lens camera; 

20 (4) The system inspects the test pattern for image displacement and/or disorientation; 

(5) The system examines the number of gray-shades, the focus, and boundary lines, 
using a 40 X 30 angle lens; and 

(6) The system generates a final report. 



Communication interface design 

In previous work (Hsieh et al., 1999), a configuration in which two cameras face 
the HMD from different directions was proposed. This design approach is shown in 
30 Figure A5. However, due to a change in cameras, specifically in the size of the 
proposed cameras, this approach was deemed no longer feasible; therefore, a new 
approach with two cameras placed in a line and an HMD on a moveable rack was 
proposed. Figure A6 shows the revised design. 

35 See See 

Figure A5. Previous design. Figure A6. Revised design. 



Before designing the communications interface for the HMD, it was important 
40 to identify in detail the operating procedure for the proposed HMD tester. This 
allowed determination of the number of sensors needed and the way the sensors 
would be integrated with the hardware. Below is a more detailed description of the 
sub-steps for steps (3) and (4) described above in section 2: 

45 • Place the HMD in the fixture. 

• Sensor #1 senses the HMD is present. 

• Sensor #2 senses the HMD is facing camera #1 . 

• System captures the image. 

• Crew chief moves the HMD to face camera #2. 
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• Sensor #3 senses the HMD in position #2. 

• System captures the image. 

Three sensors are required to accomplish the above sequence of events. One 
5 would be used to indicate the presence of the HMD, a second to indicate that the 
HMD is facing camera #1, and a third to indicate that the HMD is facing camera #2. 
Figure A7 shows the position of the sensors with respect to the HMD fixture. 

See 

10 Figure A7. Locations of sensors in proposed HMD fixture design. 

DATA ACQUISITION CARD CONFIGURATION 

A data acquisition card (DAQCard-DIO-24) by National Instruments was 
chosen to interface between the hardware sensors and the software. This card can fit 
15 into either of the notebook computer's PCMCIA slots. 

In addition, an input/output (I/O) cable and terminal block are available to 
facilitate connecting the DAQ card to external devices such as panel meters, 
instruments, and solid-state relays. Figure A8 displays this configuration. Since the 
20 proposed tester is driven (in this prototype stage) by a notebook computer to minimize 
the size of the tester, the ability to use the PCMCIA slot as the I/O interface channel 
between the sensor hardware and system software was an essential feature. 

See 

25 Figure A8. Typical DAQCard-DIO-24 configuration. 



This DAQCard-DIO-24 provides three configurable ports with 24 available 
digital I/O lines, which allow it to switch external devices such as transistors and 

30 solid-state relays, read the status of external device digital logic, and generate 

interrupts. Table 1 describes the cable pin assignment to the terminal block. Even 
numbers are signal grounds and odd numbers are the I/O signal lines. There are eight 
signals lines associated with each port (e.g., ports A, B, and C). Thus, the eight signal 
lines associated with port A are denoted as PAO, PA1, and so on, up to PA7. The 

35 same notation applies for ports B and C. 
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Table 1 . 

Pin assignments for the CB-50 terminal block. 



GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 



PC7 
PCS 
PC5 
PC4 
PC3 
PC2 
PC1 
PCO 
PB7 
PBS 



~J PB3 



GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 
GND 



PAS 
PA4 
PA3 
PA2 
PA1 
PAO 
+5V 



5 POWER SPECIFICATIONS OF THE DAQ CARD 

As shown in Table 1, pin 49 provides +5 volts (V) from the PC Card I/O 
channel power supply. This pin is referenced to ground and can be used to power 
external digital circuitry that draws up to 1.0 amps. Note that there is a resettable 
10 thermal fuse that opens at voltages exceeding 1.0 amps and returns to normal 

operating conditions when cooled. The actual current available from this signal may 
be less than 200 milliamps depending on the computer. Table 2 describes the power 
specifications for input and put signals. 
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Table 2 . 

Power specifications for input and output signals. 



Input signals 






Level 


Min 


Max 




Input logic high 
voltage 


2.2 V 


5.3 V 




Input logic low 
voltage 


-0.3 V 


0.8 V 




Input current (0 < 


-1.0 mA 


1.0 mA 




Vin < +5 V) 


(milli ampere) 


(milliampere) 


Output signals 






Pin 49 (at +5 V) | - 


| 1.0 A 



5 By default, all digital lines are pulled up to a logical HIGH setting. To keep a 

digital line in a logical LOW position, a 4.7 k£2 resistor from the digital line to ground 
can be connected in parallel with the external device. For example, to pull PC7 down 
to logical LOW, if the DAQCard-DIO-24 is connected to a CB-50 I/O terminal block 
(see Figure A7), pin 1 can be connected to any even numbered ground pin on the CB- 
10 50 pin I/O connector with a 4.7 k£2 resistor in between. 

SENSORS AND DAP CARD INTEGRATION 

As described earlier, three sensors (i.e., limited switches) are used to sense the 
HMD position and presence. Figure A9 shows how the HMD hardware fixtures, 

15 sensors, I/O cable, and DAQCard-DIO-24 card are integrated. A pull down 4.7 Mi 
resistor is utilized for each input signal pin. Input signal pins PA0, PA1, and PA2 are 
each connected to a limited switch. Reading the return value from the 8-bit I/O 
signals allows determination of which switch has been pressed. For instance, by 
default, the return value of an I/O signal is 255, since all the input pins are in logical 

20 HIGH position. A return value of 254 indicates that switch 1 has been pressed. If a 
limited switch is mounted close to camera #1, one can further interpret that HMD is 
facing camera 1. Figure A9 shows a schematic diagram of the proposed design. 

See 

25 Figure A9. Schematic diagram of proposed design. 

INTEGRATION OF SENSOR STATUS INFORMATION INTO SOFTWARE 
DESIGN 

The DAQCard-DIO-24 card is used to capture the sensors' status so that the 
30 software system can fuse this information with other sequences of events. For 

instance, knowing the status of limited switch #1 (which is mounted on the bottom of 
the enclosure) allows the system to determine if the HMD is present or not; and thus 
whether or not to activate the image capture routines. A Visual Basic function has 
been designed to query the hardware register that records the sensor status. Figures 
35 A10-A13 demonstrate the integration of an HMD setup and image capture modules 
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using feedback from the designed function. Switch #1, which indicates the presence 
of an HMD, will be mounted on the bottom of the enclosure. Switch #2, which 
indicates whether or not the HMD is facing the narrow-angle camera, will be mounted 
near the stopper on the rack by camera #1. Switch #3, which indicates whether or not 
5 the HMD is facing the wide-angle camera, will be installed near the stopper on the 
opposite side of the rack by camera #2. 

See See 
Figure A10. Initial display, Figure All. Display screen, 

1° screen, switches open. Continue button pressed, switches open. 

For details about the specifications and configuration of the DAQCard-DIO- 
24 card, please refer to the (1) DAQCard-DIO-24 user manual and (2) DAQ user 
manual for PC compatibles. For details about the code developed for this module, see 
15 Appendix B. 

See See 
Figure A12. Display screen, switches Figure A13. Display screen, 

1 and 2 pressed. image capture module activated. 



Design of image capture interface module and other features 

Revisions to previously developed modules and additional features include the 
25 following: 

• Image capture interface module: In the previous effort (Hsieh et al., 1999), 

object-linked embedding (OLE) techniques were used to launch the image capture 
driver included with the MRT Video-Port Professional software package. Based 

30 on Army recommendations, this module has been replaced with a new module 

written using the software's built-in tool-box library. Only the most essential 
functions are provided by this revised module. The revised module also provides 
an image format with a 780 x 510 pixel resolution. Figure A14 is a screenshot of 
the newly designed image capture interface module, showing an image of the 

35 HMD test pattern taken using the wide-angle camera. 

See 

Figure A14. Screenshot of image capture module. 

40 See 

Figure A15. Screenshots of parameter setting display screens. 



Password protection for system accessibility : A password is needed to enter the 
system or change parameter settings. 

Parameter setting features : Some parameters are camera dependent and/or user 
dependent. A password is needed to change parameter settings. For example, the 
size of a test pattern is camera lens angle dependent; thus, the gray-shade stripes' 
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height and width are proportional to the camera lens angle. In addition, some 
advanced system features should be user-restricted and available only to 
engineers. Figure A15 displays a parameter setting screen in which a test pattern 
is used as the background and the text boxes are displayed adjacent to the test 
5 pattern. This screen allows engineers to enter parameter values based on camera 
measurements. In addition, the image capture functions can be enabled or 
disabled. 

ALGORITHM DESIGN 

1° Following is a detailed description of the procedures used to evaluate key 

features of a test pattern such as center lines, center point, focus, test of resolution, 
and test pattern boundary. Two cameras with different angles are utilized to inspect 
different features within a test pattern. For instance, center line, center point and 
focus features are evaluated using the narrow-angle camera. On the other hand, 

15 features such as test pattern contrast and boundary characteristics are evaluated by 
using the wide-angle camera. 

These procedures detail the steps followed by the algorithm for each feature. The 
information is compiled based on the available data, which were taken from three 
20 different HMD units. In designing the algorithms, the following issues were taken 
into consideration. 

• Data collection : Images of the test pattern as taken by a narrow-angle and a wide- 
angle camera were captured for the purposes of designing the specifications, 

25 creating possible noise, and testing the proposed algorithms. These included 

images taken from different orientations (e.g., +/- 5 degrees of rotation), different 
displacements, in/out of focus, and varying contrast/brightness ratios. 

• Specification design : Correlation coefficients were frequently computed to 

30 identify the relationships between variables such as the image focus magnitude 

and gray scale variation. Strong positive or negative correlations between 
variables allow the use of one variable to predict another. For instance, there 
appears to be a strong negative relationship between image focus magnitude and 
gray scale variation. In other words, by knowing the gray scale variation, we can 

35 predict whether the HMD is in focus or not. Moreover, with sufficient data, it is 

possible to predict the extent of the lack of focus. 

• Designed noise: Knowing the types of noise present in the data helps the tester to 
differentiate between good and bad images. Although limited data were available 

40 to allow this, a few anticipated sources of noise were created to simulate real ones, 

and used to verify the proposed algorithms. Primary designed noises were 
displacement, orientation, and focus. 

Algorithms were developed to detect various features within the test pattern as 
45 described earlier. Some of the basic ideas were proposed in previous work (Hsieh et 
al., 1999). Modifications were made due to the availability of the camera. 
(Previously, images were created using graphics software. These images were of 
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course different from actual images captured from the proposed camera.) These 
procedures are described below according to the feature of interest. 

A. Identify the number of center lines. 

5 

Step 1. Apply binary image technique to the entire image. 
Step 2. Draw multiple lines across X and/or Y axes. 
Step 3. Identify mask with feature of B/W...W/B. 

Step 4. Store the intersection points in an array with multiple dimensions. 
10 Step 5. Construct regression lines based on the points within each dimension. 
Step 6. Develop regression lines to compare the parallel property. 
Step 7. Average the intersection points around the array to obtain the number of 
estimated lines, 

where B = black pixel and W = white pixel. 

15 

Note: Use of linear regression analysis would make the linear mode robust and 
insensitive to noise presence. 

How to find the threshold value needed to conduct the binary image process: 

20 

Step 1. Capture an image P(m, n) with m = 0,1,2. ...,M and n = 0,1,2. ..,N. 
Step 2. Calculate the center/horizontal lines in area A. 
Step 3. Compute the ratio y = A/P(m, n). 

Step 4. Find a knowing that the probability p(x >= + as) = y/2. 
25 Step 5. Construct binary image knowing that the threshold value T= u, + as. 

Where u is the mean and S is the standard deviation of the gray level of the image, 
and y represents the percentage of the center four-line region relative to the overall 
image area. The center four lines are the ones that have a higher gray level than the 
30 rest of the background; y/2 will provide a better contrast of the center four-line area. 

For example: Given an image P(m, n) as shown in Figure A 16. 

Step l.P(m, n) where m = 0, ...,780 and n = 0,... 510 
35 Step 2. Center area A is approximate to H+V-O 

H: horizontal line, V: four vertical lines, O: center overlap region 
H = 54 X 485, V = 758 X 10, and O = 54 X 12 
A = 33122 

Step 3. y = A/P(m, n) = 33122/(780*510) = 0.0832 
40 Step 4. p(x >=ix + as) = 0.0416, where u. = 24. 14, s = 29.67; therefore, a = 2.652 
Step 5. T= (i + as; therefore, T = 102.82 

Figure A17 shows the image after binary processing. 

45 See See 

Figure A16. Original image. Figure A17. Image after binary 

processing. 

B. Identify the center point. 
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Approach #1: 

Step 1 . Construct a regression line based on all the intercepted points. By doing so, a 
black line perpendicular to the horizontal line will be formed. 
5 Step 2. Identify the mid-point of an array as a starting point with the feature of 
W/B...B/W. 

Step 3. Examine neighboring pixels to see if a W/W/W mask exists. 
Step 4. If a W/W/W mask exists, stop the procedure; else next step. 
Step 5. Check the distance of neighboring pixels from the regression line using a 3 x 3 
10 area. 

Step 6. Select the point with the smallest distance from the regression line as the next 
point. 

Step 7. Go to step 3. 

15 Approach #2: 

Step 1. Calculate the center region of the test pattern as area A. 
Step 2. Arrange the pixel gray level in decreasing order. 
Step 3. Select the first A number of pixels. 

Step 4. Find the p(x, y) with the lowest gray level within the A number of pixels. 
20 Step 5. Compute the binary image based on the threshold value of p(x, y). 
Step 6. Calculate the center of mass: 

Center_X= Z Xj /A; Center_Y = ZY/A 

Note: Approach #2 is good only under the assumption that there are no noises that 
25 have the same gray level as the pixels within region A. 

C. Identify test pattern orientation and displacement. 

Step 1. Given an image P(m,n) with m=0,l,2...,M and n=0,l,2,...,N; 
30 Step 2. Compute a theoretical center as point C, where C=(M/2, N/2); 

Step 3. Identify the actual center point (based on part B, approach #1) as point B; 

Step 4. Connect point C and point B to form the segment S d ; 

Step 5. Compute the distance between points C and B as d, where d is the 

displacement; 

35 Step 6. If segment S d is parallel to the theoretical horizontal line or if the theoretical 
four-center lines are parallel with the actual four-center lines, then the orientation 
angle is 0; stop the process. Else go to next step; 

Step 7. Form a lines segment S a across point B, parallel to the theoretical four-center 
line, and intercepting the theoretical horizontal line; this intercept point is called point 
40 H. Form another line segment S h to connect point C and point H. 

Step 8. The angle between the line segments S d and S h is the orientation angle. 

D. Identify the number of gray shades within a test pattern. 

45 Approach #1: 

Step 1. Use the center point as a starting point. 

Step 2. Pick five points across the four vertical lines that are within the boundary of 
the gray shades. 

Step 3. Compute the average gray level of the five points. 
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Step 4. Store it in one dimension of the array. 

Step 5. If the boundary is not reached, move up or down a given distance, and go to 
Step 3. Else, go to next step. 

Step 6. Use the square root of 2 to determine the number of gray shades. 
Approach #2: 

Step 1. Identify g(x, y) h and g(x, y)i 

Step 2. Compute the ratio y = g(x, y) h / g(x, y)i 

Step 3. Repeat the same process for the four vertical lines and gray shade regions. 
10 Where g(x, y) h represents the pixel p(x, y) with the highest gray level, and g(x, 

y)i 

represents the pixel p(x, y) with the lowest gray level. 

E. Identify boundary lines. 

15 

Step 1. Use the center point and boundary ratio to determine the region of the image 
boundary. 

Step 2. Locate a starting point white pixel to use for backtracking through the rest of 
the white 

20 pixels for each line segment. 

F. Identify the focus setting. 

Step 1. Use the line scan technique to record the pixels along the four vertical lines. 
25 Step 2. Use the BAY7B mask to identify the separation of lines. 

Step 3. Compute the ratio of bottom to mid-peak and peak to valley for all four lines. 
Step 4. If the ratio is approximately one, conclude that the focus setting is good; or 
else check the 

focus setting. 

30 

G. IDENTIFY THE CONTRAST, BRIGHTNESS AND GRAY LEVEL 
RELATIONSHIP. 

Step 1 . User enters the current brightness and contrast. 
35 Step 2. System computes the average image gray level. 

Step 3. System calculates the corresponding gray level variance based on a derived 
function. 

Step 4. System computes the predicted focus magnitude. 

40 

Conclusion and future directions 

In this project, an interface was designed to allow communication between the 
sensors and the software application. This interface consists of designed circuitry, a 
45 data acquisition card, and an VO connector. It fits into a standard PCMCIA slot in a 
notebook computer. A fixture design that incorporates in-line cameras with an HMD 
holder is proposed for image capture. In addition, a new image capture software 
application was developed utilizing the tool library included in the MRT Video-Port 
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Professional image grabber software package. Algorithms were designed, taking into 
consideration the steps of data collection, design specifications, and noise generation. 
Three HMD units were utilized to capture image data. Images with noise such as 
displacement, orientation, and focus were captured. Statistical approaches such as 
correlation coefficients and regression analysis were utilized to probe the relationship 
between performance/image variables (such as focus) and image gray level variation. 
Knowledge of these relationships allows use of image variables to verify and/or 
predict control variables such as focus resolution. 

Image measurement specifications were developed based on statistical 
analysis of the collected image data. Algorithms for detecting four vertical lines, 
center point, focus, and boundary are proposed. Examples are given to illustrate how 
the procedures work and screenshots of the before and after image processing are 
shown. 

Future work will likely include: 

• Coding of the designed image specification and algorithms and verification with 
image data collected from the field. 

• Fabrication of the image tester with a robust fixture holder which has three spring 
loaded jags to provide constant pressure around the HMD and to accommodate 
variation between HMDs. 

• Field evaluation of tester accuracy. 
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APPENDIX A. 



List of manufacturers . 

5 National Instruments 

1 1500 Mopac Expressway 
Austin, TX 78759-3504 
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EXIT SETTING FORM 

Option Explicit 

Private Sub Image2_Click() 

End Sub 

Private Sub nolButton_Click() 

password.Show 
Unload exitwnd 

End Sub 

Private Sub yesButton_Click() 

Unload password 
Unload Me 



APPENDIX B. 
Program code . 



30 Private Sub Framel_DragDrop(Source As Control, X As Single, Y As Single) 
End Sub 

Private Sub Timerl_Timer() 

35 

Dim PauseTime, Start 

PauseTime = 2 'Set duration. 
Start = Timer ' Set start time. 
40 Do While Timer < Start + PauseTime 

DoEvents ' Yield to other processes. 
Loop 

Unload Me 
password.Show 

45 

End Sub 



DIONEPORTBACKUP FORM 

50 Option Explicit 
Option Base 0 

' Constant for PrintText 

55 Const LEN_PRINTTEXT = 4096 
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SUBROUTINE: PrintText 

DESCRIPTION: PrintText to desired TextBox (upto 4096 characters) 
INPUTS: txtBox - TextBox to print on 
strText - Text to print 



Sub PrintText(txtBox As TextBox, strText As String) 

txtBox.Text = Right$(txtBox.Text + strText$ + Chr$(13) + Chr$(10), LEN_PRINTTEXT) 

txtBox.SelStart = Len(CStr(txtBox.Text)) 

DoEvents 
End Sub 



' SUBROUTINE: cmdExit_Click 
' DESCRIPTION: Clean up and exit 



Sub cmdExit_Click() 

End 
End Sub 



'SUBROUTINE: ForrnLoad 
30 ' DESCRIPTION: Gets automatically called al 

> ***************** ******* 

Sub Form_Load() 

If (FlagLabel = 0) Then 
35 Stepl.BackColor = &H80FF80 

Call PrintText(txtStatusBox, "Place HMD ii 
Else 

Stepl.BackColor = &HFFFFFF White 
Stepl.ForeColor = &H8000000F Black 
40 End If 

End Sub 



'SUBROUTINE: cmdContinue_Click 
'DESCRIPTION: The main NI-DAQ operations ai 



Sub cmdContinue_CIick() 



' Local Variable Declarations: 

Dim iStatus As Integer 

Dim iRetVal As Integer 

Dim iDevice As Integer 

Dim iPort As Integer 

Dim iMode As Integer 

Dim iDir As Integer 

Dim iPattern As Long 

Dim ilgnoreWarning As Integer 

Dim PauseTime, Start 

iDevice% = 1 

'Temporarily disable buttons for protection from DoEvents' 
cmdContinue.Enabled = False 
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cmdExit.Enabled = False 

Configure port as input, no handshaking. 

5 iStatus% = DIG_Prt_Config(iDevice%, iPort%, iMode%, iDir%) 

iRetVal% = NIDAQErrorHandler(iStatus%, "DIG_Prt_Config", iIgnoreWarnmg%) 
iStatus% = DIG_In_Prt(iDevice%, iPort%, iPattern&) 

iRetVal% = NIDAQErrorHandler(iStatus%, "DIG_In_Prt", iIgnoreWarning%) 

10 

' PAO -- HMD position switch; On/254, Off/255 
' PA1 -- HMD in camera #1 position; On/253, Off/255 
' PA2 - HMD in camera #2 position; On/251, Off/255 
1 5 ' HMD lucked in camera #1 ; then, iPattern& = 252 
' HMD lucked in camera #2; then, iPattem& = 250 
' Cover is opened; then, iPattem& = 255 

>***************** ****************************** ************** 
20 If ((iPattern& = 25 1 ) Or (iPattern& = 253) Or (iPattern& = 255)) Then 

Call PrintText(txtStatusBox, "Enclosure is open !") 
End If 

25 If ((iPattern& = 252) And (FlagLabel = 0)) Then 

Call PrintText(txtStatusBox, "Positon is lucked ! Loading program ") 
Stepl.BackColor = &HFFFFFF White 
Stepl.ForeColor = &H8000000F Black 
30 Step2.BackColor = &H80FF80 light Green 



PauseTime = 2 'Set duration. 
Start = Timer ' Set start time. 
35 Do While Timer < Start + PauseTime 

DoEvents ' Yield to other processes. 
Loop 

Unload Me FormlBackup 
40 Image_Capture.Show 

Stepl .BackColor = &HFFFFFF White 
Stepl .ForeColor = &H8000000F Black 
Step2.BackColor = &HFFFFFF White 
45 Step2.ForeColor = &H8000000F Black 

Step3.BackColor = &H80FF80 Tight Green 

Call PrintText(txtStatusBox, "Place HMD in position indicated for use with wide-angle camera; then press 
Continue button below") 

50 

FlagLabel = FlagLabel + 1 Flag for sequencing the events 



65 



End If 

If ((iPattern& = 250) And (FlagLabel = 1)) Then 

Call PrintText(txtStatusBox, "Positon is lucked ! Loading program ") 

Stepl .BackColor = &HFFFFFF White 
Stepl .ForeColor = &H8000000F Black 
Step3 .BackColor = &HFFFFFF White 
Step3 .ForeColor = &H8000000F Black 
Step4.BackColor = &H80FF80 light Green 

PauseTime = 2 'Set duration. 
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Start = Timer ' Set start time. 

Do While Timer < Start + PauseTime 

DoEvents ' Yield to other processes . 
Loop 

Unload Me 
Image_Capture.Show 

FlagLabel = FlagLabel + 1 

End If 



If (FlagLabel = 2) Then 



Stepl.BackColor = 
Stepl.ForeColor = 
Step2.BackColor = 
Step2.ForeColor = 
Step3.BackColor = 
Step3.ForeColor = 
Step4.BackColor = 
Step4.ForeColor = 
Step5.BackColor = 



= &HFFFFFF White 

&H8000000F Black 

= &HFFFFFF White 

&H8000000F -Black 

= &HFFFFFF White 

&H8000000F -Black 

= &HFFFFFF White 

&H8000000F Black 

: &H80FF80 -Light Gr. 



Call PrintText(txtStatusBox, "Press Return button below to return to main menu ") 
FlagLabel = FlagLabel + 1 

End If 

If (FlagLabel < 3) Then 

cmdContinue.Enabled = True 
Else 

cmdContinue.Enabled = False 
End If 

cmdExit.Enabled = True 
End Sub 

Private Sub Imagel_Click() 
End Sub 

Private Sub Return_Click() 

If (FlagLabel = 3) Then 

Step5.BackColor = &HFFFFFF White 

Step5.ForeColor = &H8000000F Black 
End If 

Unload FormlBackup 
Form2.Show 



End Sub 



55 820F2FORM 



Private Sub Form_Load() 

If (Dummy Y = 0) Then 
60 cmdImage_Analysis.Enabled = False 
cmdResults.Enabled = False 
cmdSetup.Enabled = True 

Else 
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cmdImage_Analysis.Enabled = True 
cmdResults.Enabled = True 
cmdSetup.Enabled = False 

End If 

End Sub 

Private Sub cmdSettings_Click() 

Unload Form2 
passwordforsettings.Show 

cmdSettings.Enabled = False 'once it is set; u can't go back 
End Sub 

Private Sub cmdSetup_Click() 

cradSetup.ToolTipText = "Set up the HMD" 

Unload Form2 
Forml Backup. Show 

Dummy Y = 1 'to de-activate the functions 
End Sub 

Private Sub cmdImage_Capture_Click() 

cmdImage_Capture.ToolTipText = "Image capture of the HMD" 
Unload Form2 

cmdImage_Capture.Enabled = False 

Image_Capture.Show 

End Sub 

Private Sub cmdImage_Analysis_Click() 

cmdImage_Analysis.ToolTipText = "Image features analysis" 

Unload Form2 
Form4.Show 

MsgBox "Select an image file" 
End Sub 

Private Sub cmdResults_Click() 

cmdResults.ToolTipText = "Analysis findings" 

Unload Form2 
Form5.Show 

End Sub 

Private Sub cmdQuit_Click() 

cmdQUIT.ToolTipText = "Exit from the system" 

Unload Form2 
End 

End Sub 

Private Sub Imagel_Click() 
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End Sub 



82QF479 00 FORM 

Public Displacement, Angle As Double 

Public CenterLineSlope As Double 

Public CenterLinelntercept As Double 

Public Center_Point_X, Center_Point_Y As Double 

Const intUpperBoundX = 780 320 total 
Const intUpperBoundY = 510 244 total 
Const n = 4 '# of center line 

Dim X, Y As Integer 

Dim picObjectO, picObjectl As Image Do not delete picObjectl; U used picObjectl somewhere in the form 

Dim picObject3 As Picture 

Dim Coord_X(0 To 45, 0 To 10) As Integer 

Dim Coord_Y(0 To 45, 0 To 10) As Integer 

Dim pixels(0 To intUpperBoundX, 0 To intUpperBoundY) As Long 
Dim ImagePixels(2, intUpperBoundX, intUpperBoundY) As Integer 

Private Sub Back_Click() 

cmdBack.ToolTipText = "Back to previous stage" 

Unload Form4 

Form2.Show 

End Sub 

Private Sub cmdFocus_Click() 
cmdFocus.ToolTipText = "Focus Measurement" 

'Hs****** ********************* 

'Step 1: Calculate the image standard deviation 
'Step 2: 

'****************************** S!N:H:4 . S!sN:i!H:H ;^^. H .^^ :i . H .,. 

Set PictureO.Picture = picObjectO 
For X = 0 To intUpperBoundX - 1 

For Y = 0 To intUpperBoundY - 1 

PictureO.PSet (X, Y), Picture0.Pomt(X, Y) - 10 

Next Y 
NextX 



End Sub 

Private Sub Form_Load() 

cmdFocus.Enabled = False 
cmdGray_Shade.Enabled = False 
cmdCenter_and_Boundary.Enabled = False 
cmdEdgeDetection.Enabled = False 
cmdGray_Shade.Enabled = False 
cmdDis_and_Orientation.Enabled = False 

End Sub 

Private Sub cmdGray_Shade_Click() 

cmdGray_Shade.ToolTipText = "Detecting number of gray shades" 
End Sub 
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Private Sub cmdSelect_Click() 

Dim filename, EdgeDetection As String 
5 Dim bytRed, bytGreen, bytBlue, bytAverage As Integer 
Dim GrayLong As Long 

Dim SumGrayLevel, MeanGray, SumSquare, StandardDeviation, ThreshoIdValue As Double 

cmdSelect.ToolTipText = "Select an image file first" 

On Error GoTo FileError 

If (Right$(Dirl.Path, 1) = "\") Then 

filename = Filel.Path & File 1. filename 
Else 

15 filename = Filel.Path & "\" & Filel. filename 
End If 

Open filename For Input As #1 

20 Set picObjectO = LoadPicture(filename) 
Set PictureO.Picture = picObjectO 

Close #1 

25 Do not reverse the sequence: imagel and pictureO 



Open "c:\windows\desktopMmageMap.txt" For Output As #2 

30 For X = 0 To intUpperBoundX - 1 
For Y = 0 To intUpperBoundY - 1 

pixels(X, Y) = PictureO.Point(X, Y) 

35 If (pixels(X, Y) = 0) Then 

bytRed = 0 
bytGreen = 0 
bytBlue = 0 
End If 

40 

If (pixels(X, Y)>0)Then 
bytRed = GetRed(pixels(X, Y)) 
bytGreen = GetGreen(pixels(X, Y)) 
bytBlue = GetBlue(pixels(X, Y)) 
45 End If 

If (Y = 150) Then 

bytAverage = (bytBlue + bytRed + bytGreen) / 3 
Write #2, X, Y, bytRed, bytBlue, bytGreen, bytAverage 
50 End If 

1magePixels(0, X, Y) = bytRed 
1magePixels(l, X, Y) = bytGreen 
TmagePixels(2, X, Y) = bytBlue 
55 'the file u have is in gray scale; therefore, u do not need to average 

PictureO.PSet (X, Y), RGB(bytRed, bytGreen, bytBlue) 

Next Y 
60 NextX 

Close #2 

"SumGrayLevel = 0 
65 For X = 0 To intUpperBoundX - 1 
' For Y = 0 To intUpperBoundY - 1 
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' SumGrayLevel = SumGrayLevel + ImagePixels(0, X, Y) 

' NextY 

"NextX 

5 MeanGray = SumGrayLevel / (intUpperBoundX * intUpperBoundY) 
'SumSquare = 0 

Tot X = 0 To intUpperBoundX - 1 
' For Y = 0 To intUpperBoundY - 1 
10 ' SumSquare = SumSquare + ((ImagePixels(0, X, Y) - MeanGray) * (ImagePixels(0, X, Y) - MeanGray)) 
' NextY 
TCextX 

'StandardDeviation = SumSquare / ((intUpperBoundX * intUpperBoundY) - 1) 
1 5 ThresholdValue = MeanGray + (2.5 * StandardDeviation) 



If Filel. filename = "Narrow.bmp" Then 
cmdEdgeDetection.Enabled = True 
20 cmdDis_and_Orientation.Enabled = True 
cmdFocus.Enabled = True 

MsgBox "Select one of the criterion on the left top corner" 
End If 

25 If Filel.filename = "Wide.bmp" Then 
cmdGray_Shade.Enabled = True 
cmdCenter_and_Boundary.Enabled = True 
MsgBox "Select one of the criterion on the left bottom corner" 
End If 

30 

Exit Sub 

FileError: MsgBox "Select an image file first !" 
35 End Sub 

Private Sub cmdCenter_and_Boundary_Click() 

^ cmdCenter_and_Boundary.ToolTipText = "Finding the center lines and boundary" 

Set PictureO.Picture = picObjectO 
For X = 0 To intUpperBoundX - 1 
For Y = 0 To intUpperBoundY - 1 
PictureO.PSet (X, Y), PictureO.Point(X, Y) 
45 Next Y 
NextX 

Set picObjectS = PictureO.Picture 
SavePicture picObject3, "TEST1.BMP" 
50 LoadPicture ("TEST1.BMP") 

MsgBox "Boundary rountine ended !" 

End Sub 

55 

Private Sub cmdEdgeDetection_Click() 

Dim RGBLong As Long 
Dim G_X, G_Y, G_X_Y As Integer 
60 Dim bRXY, bRXmlY, byRXYml , bRXml Yml As Integer 

Dim bRXplY, bRXYpl, bRXpl Ypl, bRXplYml, bRXmlYpl As Integer 
Dim bytRed, bytGreen, bytBlue As Integer 

cmdEdgeDetection.ToolTipText = "Edge Detection" 

65 

Set PictureO.Picture = picObjectO 
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For X = 0 To intUpperBoundX - 1 
For Y = 0 To intUpperBoundY - 1 

5 If (X = 0 Or X = intUpperBoundX - 1 Or Y = 0 Or Y = intUpperBoundY - 1) Then 

bytRed = ImagePixels(0, X, Y) 
bytBlue = ImagePixels(l, X, Y) 
bytGreen = ImagePixels(2, X, Y) 
1 0 RGBLong = RGB(bytRed, bytGreen, bytBlue) 

PictureO.PSet (X, Y), RGBLong 

Else 

15 

G_X = 0 
G_Y = 0 
G_X_Y = 0 

20 bRXY = ImagePixels(0, X, Y) 

bRXYpl = ImagePixels(0, X, Y + 1) 

bRXmlY = ImagePixels(0, X - 1, Y) 

bRXYml = ImagePixels(0, X, Y - 1) 

bRXml Ypl = ImagePixels(0, X - 1, Y + 1) 
25 bRXml Yml = ImagePixels(0, X - 1, Y - 1) 

bRXplY = ImagePixels(0, X + 1, Y) 

bRXpl Yml = ImagePixels(0, X + 1, Y - 1) 

bRXpl Ypl = ImagePixels(0, X + 1, Y + 1) 

30 G_X = bRXplYml + 2 * bRXpl Y + bRXplYpl - bRXml Yml - 2 * bRXml Y - bRXml Ypl 

G_Y = bRXml Ypl + 2 * bRXYpl + bRXplYpl - bRXml Yml - 2 * bRXYml - bRXplYml 
G_X_Y = Sqr((G_X * G_X) + (G_Y * G_Y)) 

bytRed = G_X_Y 

35 

bRXY = ImagePixelsQ, X, Y) 
bRXYpl = ImagePixels(l, X, Y + 1) 
bRXml Y = ImagePixels(l, X - 1, Y) 
bRXYml = ImagePixels(l, X, Y - 1) 
40 bRXmlYpl = ImagePixels(l, X - 1, Y + 1) 

bRXml Yml = ImagePixels(l, X - 1, Y - 1) 
bRXplY = ImagePixels(l, X + 1, Y) 
bRXplYml = ImagePixels(l, X + 1, Y - 1) 
bRXplYpl = ImagePixels(l, X + 1, Y + 1) 

45 

G_X = bRXplYml + 2 * bRXplY + bRXplYpl - bRXml Yml - 2 * bRXml Y - bRXml Ypl 
G_Y = bRXml Ypl + 2 * bRXYpl + bRXplYpl - bRXml Yml - 2 * bRXYml - bRXplYml 
G_X_Y = Sqr((G_X * G_X) + (G_Y * G_Y)) 

50 bytBlue = G_X_Y 

bRXY = ImagePixels(2, X, Y) 

bRXYpl = ImagePixels(2, X, Y + 1) 

bRXml Y = ImagePixels(2, X - 1, Y) 
5 5 bRXYml = ImagePixels(2, X, Y - 1) 

bRXml Ypl = ImagePixels(2, X - 1, Y + 1) 

bRXml Yml = ImagePixels(2, X - 1, Y - 1) 

bRXplY = ImagePixels(2, X + 1, Y) 

bRXplYml = ImagePixels(2, X + 1, Y - 1) 
60 bRXplYpl = ImagePixels(2, X + 1, Y + 1) 

G_X = bRXplYml + 2 * bRXplY + bRXplYpl - bRXml Yml - 2 * bRXml Y - bRXml Ypl 
G_Y = bRXml Ypl + 2 * bRXYpl + bRXplYpl - bRXml Yml - 2 * bRXYml - bRXplYml 
G_X_Y = Sqr((G_X * G_X) + (G_Y * G_Y)) 

65 

bytGreen = G_X_Y 
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PictureO.PSet (X, Y), RGB(bytRed, bytGreen, bytBlue) 



End If 

NextY 
NextX 

End Sub 

Private Sub cmdGray_Shade Click() 

Set PictureO.Picture = picObjectO 
For X = 0 To intUpperBoundX - 1 

For Y = 0 To intUpperBoundY - 1 

PictureO.PSet (X, Y), PictureO.Point(X, Y) - 5 

NextY 
NextX 

MsgBox "Gray shades routine ended !" 
End Sub 

Private Sub cmdDis_and_Orientation_Click() 

Const interval_range = 7 

Dim WhitePixel, BlackPixel As Long 
Dim linescan As Integer 

Dim i, j, k, 1, IntX, Temp_X, Temp_Y As Integer 
Dim Flag, SumTline, Dummy As Integer 
Dim interval As Integer 
Dim ZeroO_X, ZeroO_Y As Double 

Dim LISlopeR, L2SlopeR, L3SlopeR, L4SlopeR, LISlopeY, _ 
L2SlopeY, L3SlopeY, L4SlopeY, AvgSlope As Double 

Dim UpperBound, LowerBound As Double 

Dim InterceptY As Integer 

Dim Count_Points(0 To 403) As Integer 

Dim Templnt, Choice As Integer 

Dim Dum(0 To 15) As Double 

Dim TempDouble As Double 

Dim Tline(0 To 50) As Integer 

Dim Oripixels(0 To intUpperBoundX, 0 To intUpperBoundY) As Long 

Dim Displacement, Angle, Theta As Double 

Dim CenterLineSlope As Double 

Dim CenterLinelntercept As Double 

Dim Center_Point_X, Center_Point_Y As Double 

Dim TempText As String 

cmdDis_and_Orientation.ToolTipText = "Displacement and Orientation" 
Open "c:\windows\desktop\InspResults.txt" For Output As #1 

For X = 0 To intUpperBoundX - 1 

For Y = 0 To intUpperBoundY - 1 
Oripixels(X, Y) = pixels(X, Y) 

NextY 
NextX 

'Apply the binary image technique 

For X = 0 To intUpperBoundX - 1 
For Y = 0 To intUpperBoundY - 1 
If (Oripixels(X, Y) < RGB(255, 255, 255)) Then 
Oripixels(X, Y) = 0 
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Else 

Oripixels(X, Y) = RGB(255, 255, 255) 
End If 

PictureO.PSet (X, Y), Oripixels(X, Y) 

NextY 
NextX 



Find the number of center lines 
10 'A line is BW...WB; if there is less than four BW...WBs; then Image is tilled 
'white interval should be less than 7 for the central lines 
"use Black/White/Black to find a line 



line scan = 0 
15 interval = 1 



For Y = 50 To intUpperBoundY - 1 
Tline(linescan) = 0 
Flag = 0 
20 1 = 0 



For X = 0 To intUpperBoundX - 1 
If ((Oripixels(X, Y) = RGB(0, 0, 0)) And _ 
^ (Oripixels(X + 1, Y) = RGB(255, 255, 255))) Then 

For interval = 1 To interval_range - 1 
If (Oripixels(X + 1 + interval, Y) = RGB(0, 0, 0)) Then 

Tline(linescan) = Tline(linescan) + 1 
30 Flag = 1 



Coord_X(linescan, 1) = X + 
Coord_Y(linescan, 1) = Y 



End If 

interval = interval_range 'stop the for loop 
Next interval 
40 End If 

NextX 

Y = Y + 1 0 ' 5 'to have 40 arbitary verticle lines 
If (Flag = l)Then 
linescan = linescan + 1 
45 End If 
NextY 



k = 0 

SumTline = 0 

50 For j = 0 To linescan - 1 'from prev. routine # of arb. ver. lines 
If(Tline(j)>0)Then 
SumTline = SumTline + Tline(j) 
k = k+ 1 
End If 
55 Nextj 



If (3.5 <= (SumTline / k) <= 4.5) Then 
MsgBox ("Number of center lines is " & n) 

60 Ll SlopeR = GetSlope(linescan, 0, 0) 
LISlopeY = GetSlope(linescan, 0, 1) 

L2SlopeR = GetSlope(linescan, 1, 0) 
L2SlopeY = GetSlope(linescan, 1, 1) 

65 

L3SlopeR = GetSlope(linescan, 2, 0) 
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L3SlopeY = GetSlope(linescan, 2, 1) 

L4SlopeR = GetSlope(linescan, 3, 0) 
^ L4SlopeY = GetSlope(linescan, 3, 1) 

AvgSlope = (LISlopeY + L2SlopeY + L3SlopeY + L4SlopeY) / 4 
LowerBound = 0.025 * AvgSlope 
UpperBound= 1.025 * AvgSlope 

10 Use the absolute value; therefore, it works on both -/+ values 

If ((Abs(LowerBound) <= Abs(LlSlopeY) <= Abs(UpperBound)) And_ 
(Abs(LowerBound) <= Abs(L2SlopeY) <= Abs(UpperBound)) And _ 
(Abs(LowerBound) <= Abs(L3SlopeY) <= Abs(UpperBound)) And _ 
1 5 (Abs(Lo werBound) <= Abs(L4SlopeY) <= Abs(UpperBound))) Then 

MsgBox ("Four lines are parallel !") 

Else: MsgBox ("Potential errors in finding parallel lines") 

End If 

20 Else 

MsgBox ("Number of center lines is " & SumTline / k) 
End If 

The following is to find the center point of the image 
25 Step 1 : Find the black pixel 

Step 2: Calcuate the neighborhood pixels distance to the regression line 
Step 3: Locate the one that has the smallest distance 
Step 4: Check to see if the feature of w 

30 ' 

'been meet 

'if not; based on current X, Y; go to Step 1 

BlackPixel = RGB(0, 0, 0) 
35 WhitePixel = RGB(255, 255, 255) 

CenterLineSlope = GetSlope(linescan, 0, 2) 
CenterLinemtercept = GetSIope(lmescan, 0, 3) 

40 MsgBox ("C.L.Intercept = " & CenterLinemtercept) 
MsgBox ("C.L.Slope = " & CenterLineSlope) 

For Y = 20 To intUpperBoundY - 1 
X = (Y * CenterLineSlope) + CenterLinemtercept 
45 IntX = X 

If (Oripixels(IntX, Y) = BlackPixel) Then 

1 = 0 

Temp_X = 0 
50 Temp_Y = 0 

For i = -1 To 1 
Forj =-1 To 1 
If (Oripixels(IntX + i, Y + j) = WhitePixel) Then 
Temp_X = Temp_X + (IntX + i) 
5 5 Temp_Y = Temp_Y + ( Y + j) 

1 = 1+1 
End If 

If (1 >= 3) Then 'Neighborhood pixels are White 
Center_Point_X = Temp_X / 1 
60 Center_Point_Y = Temp_Y / 1 

MsgBox ("Center X = " & Center_Point_X) 
Beep 

MsgBox ("Center Y = " & Center_Point_Y) 
i = 1 

65 j = l 

Y= intUpperBoundY 
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End If 
Next j 
Next i 

5 1 = 0 

Dum(l) = 0 
For i = 0 To 1 
Forj = 0To 1 
If(ioOOrjoO)Then 
10 Dum(l) = Measure_Distance(CenterLineIntercept, CenterLineSlope, X + i, Y + j) 

1 = 1 + 1 
End If 
Nextj 
Nexti 

15 

Fork = 0Tol- 1 
If (Dum(k) < Dum(k + 1)) Then 
TempDouble = Dum(k) 
Dum(k) = Dum(k + 1) 
20 Dum(k + 1) = TempDouble 

End If 
Nextk 

For i = 0 To 1 
25 Forj =0 To 1 

If ((i <> 0 Or j <> 0) And (DurnQ - 1) = Measure_Distance(CenterLineIntercept, CenterLineSlope, X + i, 
Y + j)))_ 

Then_ 

30 X = X + i 

Y = Y + j - 1 because Y auto. inc. by 1 

j = l 

35 End If 

Nextj 
Nexti 

End If 

40 PictureO.PSet (IntX, Y), RGB(255, 255, 255) 
Next Y 

The following section is to find the orientation and displacement 
45 'Comparing the theoretical zero point and new zero point 
'Calculate the displacement and titled angle 

ZeroO_X = (intUpperBoundX - 1) / 2 
ZeroO_Y = (intUpperBoundY - 1) / 2 

If ((Center_Point_X - ZeroO_X = 0) And (Center_Point_Y - ZeroO_Y = 0)) Then 

Theta = 0 
Displacement = 0 

55 

Else 

Displacement = Sqr((Center_Point_X - ZeroO_X) A 2 + (Center_Point_Y - ZeroO_Y) A 2) 
TempDouble = (Center_Point_Y - ZeroO_Y) / Displacement 
60 Theta = Atn(TempDouble / Sqr(-TempDouble * TempDouble + 1)) 
Angle = 90 - ((Theta/ 3.141592654) * 180) 

End If 

65 MsgBox ("Titled angle is (clockwise): " & Angle) 
MsgBox ("Displacement is: " & Displacement) 
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For X = 0 To intUpperBoundX - 1 
For Y = 0 To intUpperBoundY - 1 
PictureO.PSet (X, Y), RGB(255, 255, 255) 
5 Next Y 
NextX 

For i = 0 To 6 

1 0 PictureO.CurrentX = 20 

PictureO.CurrentY = 20 + 15 * i 
Select Case i 
Case 0: 

PictureO.Print ("Number of center lines are " & n) 
15 TempText = "Number of center lines are: " 

Write #1, TempText, n 

Casel: 

PictureO.Print ("C.L.Intercept = " & CenterLinelntercept) 
20 Write #1, "C.L.Intercept = ", CenterLinelntercept 

Case 2: 

PictureO.Print ("C.L.Slope = " & CenterLineSlope) 
^ Write #1, "C.L.Slope = ", CenterLineSlope 

Case 3: 

PictureO.Print ("Center X = " & Center_Point_X) 
Write #1, "Center X = Center_Point_X 

30 Case 4: 

PictureO.Print ("Center Y = " & Center_Point_Y) 
Write #1, "Center Y = ", Center_Point_Y 

Case 5: 

3 5 PictureO.Print ("Titled angle is (clockwise): " & Angle) 

Write #1, "Titled angle is (clockwise): ", Angle 

Case 6: 

PictureO.Print ("Displacement is: " & Displacement) 
40 Write #1, "Displacement is ", Displacement 

End Select 
Nexti 
Close #1 

45 

MsgBox "Ori & Dis. routine ended !" 
End Sub 

50 Private Sub cmdQuit_Click() 

cmdQUIT.ToolTipText = "Exit the system" 

Unload Form4 
55 Exit Sub 

' Form2.Show 

End Sub 

Private Sub cmdBack_Click() 

60 

cmdBack.ToolTipText = "Back to previous stage" 

Unload Form4 
Image_Capture.Show 
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End Sub 

Private Sub Dirl_Change() 

Filel.Path = Dirl.Path 
End Sub 

5 Private Sub Drive l_Change() 
Dirl.Path = Drivel.Drive 
End Sub 

Function GetRed(colorVal As Long) As Integer 

GetRed = colorVal Mod 256 
10 End Function 

Function GetGreen(colorVal As Long) As Integer 

GetGreen = ((colorVal And &HFF00FF00) / 256&) 
End Function 

Function GetBlue(colorVal As Long) As Integer 
1 5 GetBlue = (colorVal And &HFF0000) / (256& * 256&) 

End Function 

Function GetSlope(Points As Integer, LineN As Integer, Choice As Integer) As Double 

Dim SumXY, SumX, SumY As Double 
Dim SumYsq, SumXsq, FuncDumy As Double 
Dim a, Index, Position_X, Position_Y As Integer 

SumXY = 0 
SumX = 0 
SumY = 0 
SumXsq = 0 
SumYsq = 0 
Position_X = 0 
Position_Y = 0 
Index = 0 
FuncDumy - 0 

'Sometimes the image is trancated; u do not have 
'all the 18 points; we use the B to represent to count 
'all the points 

'Choice 0: Line correlation coefficient 
'Choice 1 : Parallel line slope 
^Choice 2: Center line slope 
'Choice 3: Center line intercept 

If (Choice = 0 Or Choice = 1) Then 
For a = 0 To Points - I 
Position_X = Coord_X(a, LineN) 
Position_Y = Coord_Y(a, LineN) 

If ((Position_X O 0) And (Position_Y <> 0)) Then 
SumXY = SumXY + (Position_X * Position_Y) 
SumX = SumX + Position_X 
SumY = SumY + Position_Y 
SumYsq = SumYsq + Position_Y A 2 
SumXsq = SumXsq + Position_X A 2 
Index = Index + 1 
End If 
Next a 

End If 

If (Choice = 2 Or Choice = 3) Then 
For a = 0 To Points - 1 
60 For LineN = 0 Ton- 1 

Position_X = Coord_X(a, LineN) 
Position_Y = Coord_Y(a, LineN) 

If ((Position_X o 0) And (Position_Y o 0)) Then 
65 SumXY = SumXY + (PositionX * Position_Y) 

SumX = SumX + Position_X 
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SumY = SumY + Position_Y 
SumYsq = SumYsq + Position_Y A 2 
SumXsq = SumXsq + Position_X A 2 
Index = Index + 1 

5 

End If 
Next LineN 
Next a 
End If 

10 

If ((SumX = 0) Or (SumY = 0) Or (SumX * SumY = 0)) Then 

GetSlope = 0 
Else 

If (Choice = 1 Or Choice = 2) Then 
1 5 GetSlope = ((SumXY) - ((SumX * SumY) / Index)) / ((SumYsq) - ((SumY * SumY) / Index)) 

End If 

If (Choice = 3) Then 

FuncDumy = ((SumXY) - ((SumX * SumY) / Index)) / ((SumYsq) - ((SumY * SumY) / Index)) 
20 GetSlope = (SumX - (FuncDumy * SumY)) / Index 

End If 

If (Choice = 0) Then 

FuncDumy = Sqr((SumXsq - (SumX A 2 / Index)) * (SumYsq - (SumY A 2 / Index))) 
25 GetSlope = ((SumXY) - ((SumX * SumY) / Index)) / FuncDumy 

End If 
End If 

30 End Function 

Function dblSquare(SquareMe As Integer) As Double 

dblSquare = SquareMe A 2 * SquareMe 

35 End Function 

Function Measure_Distance(cl As Double, ml As Double, Point2_X As Integer, Point2_Y As Integer) As Double 

Dim Pointl_X, Pointl_Y As Long 
Dim c2 As Long 

40 

c2 = Point2_X - ((-1 / ml) * Point2_Y) 

Pointl_X = (c2 * ml - cl * (-1 / ml)) / (ml - (-1 / ml)) 

Pointl_Y = (c2 - cl) / (ml - (-1 / ml)) 

Measure_Distance = Sqr((Point2_X - Pointl_X) A 2 + (Point2_Y - Point 1_Y) A 2) 

45 

End Function 

Private Sub PictureO_Click() 
50 End Sub 



820F5 FORM 



Private Sub cmdBack_Click() 

55 

cmdBack.ToolTipText = "Back to previous stage" 

Unload Form5 
Form4.Show 

60 

End Sub 

Private Sub Picture2_Click() 
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End Sub 



30 



Private Sub cmdQuit_Click() 

cmdQuit.ToolTipText = "Exit from the system" 

Unload Form5 
Exit Sub 

End Sub 

Private Sub cmdShowRes_Click() 
Dim NewLine As String 

cmdShowRes.ToolTipText = "Display the inspection results" 
On Error GoTo FileError 

Open "c:\windows\desktop\InspResults.txt" For Input As #1 
Do Until EOF(l) 
Line Input #1, NewLine 

TEXT 1. Text = TEXT 1. Text + NewLine + vbCrLf 
Loop 

Exit Sub 

FileError: 
MsgBox "File Error! " 

End Sub 

Private Sub Form_Load() 
End Sub 



35 IMAGE CAPTURE FORM 

Dim cfg As VPX_Config 
DimhDIB As Long 
Dim numAverage As Integer 
40 Dim prevAveragelndex As Integer 
Dim ffltOn(8) As Boolean 
Dim filt(8) As Long 
Dim avgNums(6) As Integer 
Dim Err As Integer 

45 

Private Declare Function GlobalFree Lib "KERNEL32" (ByVal handle&) As Long 
Sub SetupMenu() 
Dim Enable As Boolean 

Enable = cfg.outputFormat = VPP_mono Or cfg.outputFormat = VPP_BGR24 

50 

TmageCaptureFunctionEnable initialized in the password Form 

For i% = 1 To 6 

If (ImageCaptureFunctionsEnable = 0) Then 
55 Average(i%).Enabled = False 

End If 

If (ImageCaptureFunctionsEnable =1) Then 

Average(i%).Enabled = True 
End If 
60 Next Wo 



For Wo = 1 To 8 

If (ImageCaptureFunctionsEnable = 0) Then 
Filter(i%).Enabled = False 
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End If 

If (ImageCaptureFunctionsEnable =1) Then 

Filter(i%).Enabled = True 'enable 
End If 
5 Next i% 

If (ImageCaptureFunctionsEnable = 0) Then 

ImageFormat.Enabled = False 

Copy.Enabled = False 
10 End If 

If (ImageCaptureFunctionsEnable =1) Then 

ImageFormatEnabled = True User sh not have aces to ths fun 

Copy.Enabled = True 
End If 

15 

End Sub 

Private Sub Average_Click(Index As Integer) 
20 Average(prevAverageIndex).Checked = False 

Average(Index).Checked = True 

prevAveragelndex = Index 

numAverage = avgNums(Index) 
End Sub 

25 

Private Sub Copy_Click() 

IfhDIBoOThen 
DimhDIB2 As Long 
30 Check (VPX_copyDIB(hDIB, hDIB2)) 

Check (VPX_saveDIBToClipboard(hDIB2)) 
End If 
End Sub 

35 Private Sub Exit_Click() 

Unload Image_Capture 
Forml Backup.Show 

40 

End Sub 

Private Sub filter_Click(Index As Integer) 
filtOn(Index) = Not filtOn(Index) 
45 Filter(Index).Checked = filtOn(Index) 
End Sub 

Private Sub Form_Load() 

50 hDIB = 0 

numAverage = 1 

prevAveragelndex = 1 

Fori% = 1 To 8 
filtOn(i%) = False 
55 Next i% 

filt(l) = VPX_AVERAGE 

filt(2) = VPX_SMOOTH 

filt(3) = VPX_DETAIL 

filt(4) = VPX_SHARPEN 
60 filt(5) = VPX_AI 

filt(6) = VPX_AISHARPEN 

filt(7) = VPX_VERTLINES 

filt(8) = VPX.HORIZLINES 

avgNums(l) - 1 
65 avgNums(2) = 2 

avgNums(3)=3 
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avgNums(4) = 4 
avgNums(5) = 8 
avgNums(6) =16 
Check (VPPJnitO) 
5 Err = VPX_readIniFile(".\test.ini", "DEFAULT", cfg) 

Check (VPX_prepare(cfg, VPP_true)) 

If cfg.outputFormat = VPP_mono Or cfg.outputFormat = VPP_mono4 Then 

Err = VPX_defaultPalette(Image_Capture.hDC, VPP„true) 
Else 

10 Err = VPX_defaultPalette(Image_Capture.hDC, VPP_false) 

End If 
SetupMenu 

Timerl .Enabled = True 
End Sub 

15 

Private Sub Form_Unload(Cancel As Integer) 
If hDIB o 0 Then 

GlobalFree (hDIB) 
End If 

20 Timerl .Enabled = False 

Check (VPX_saveIniFile(".\test.ini", "DEFAULT", cfg)) 
Err% = VPX_releasePalette() 
Check (VPP_closedown(VPP_true)) 
End Sub 

25 

Private Sub ImageFormat_Click() 

Timerl .Enabled = False 
Err = VPX_formafDialogBox(0, 0, cfg) 
30 Err = VPX_prepare(cfg, VPP_trae) 

SetupMenu 

Timerl .Enabled = True 
End Sub 

3 5 Private Sub Save_Click() 
If hDIB o0 Then 

Check (VPX_saveDIBToFile(hDIB, "Atest.bmp")) 
End If 

40 End Sub 

Private Sub Timer l_Timer() 
Dim formatOk As Boolean 
Timerl. Enabled = False 
45 If hDIB oO Then 

handle& = GlobalFree(hDIB) 
End If 

formatOk = cfg.outputFormat = VPP_mono Or cfg.outputFormat = VPP_BGR24 
If numAverage > 1 And formatOk Then 
50 En = VPX_snapAverageDIB(cfg, hDIB, numAverage, numAverage) 

Else 

Err = VPX_snap(cfg) 
En = VPX_readoutDIB(cfg, hDIB) 
End If 

55 Fori% = lTo8 

If filtOn(i%) And formatOk Then 

Err = VPX_filterDIBPredef(hDIB, VPX_getFilter(filt(i%))) 
End If 
Next i% 

60 Err = VPX_drawDIB(Image_Capture.hDC, hDIB, 0, 0, 0, 0) 

Dim intLoopIndex As Integer 
Tor intLoopIndex = 0 To 17 

' Line (1000, 1000 + 400 * intLoopIndex)-(3500, 1000 + 400 _ 
65 ' * intLoopIndex), RGB(255, 255, 0) 

"Next intLoopIndex 
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The following is the boundary of the image 

Line (220, 7550)-(11400, 7550), RGB(255, 255, 0) Bot.Hoz. 
5 Line (220, 280)-(l 1400, 280), RGB(255, 255, 0) Top Hoz. 

Line (220, 7550)-(220, 280), RGB(255, 255, 0) Left Ver. 
Line (11400, 7550)-(11400, 280), RGB(255, 255, 0) Ttgt Ver. 

The following is the cross-hair of the area 

10 

Line (5675, 3913)-(5975, 3913), RGB(255, 255, 0) Horizontal line 
Line (5825, 4013)-(5825, 3813), RGB(255, 255, 0) -Verticle line 

Timer 1 .Enabled = True 
1 5 End Sub 



820PASSWORD FORM 

Private Sub cmdLogin_Click() 

20 If txtpasswd-Text = "password" Then 
Unload password 

Initialize the settigns 

25 Dummy Y = 0 

ImageCaptureFunctionsEnable = 0 

Form2.Show 

MsgBox "Please set up the HMD first !" 

30 

Else 

MsgBox "Wrong Passord ! Please enter again !" 



35 End If 
End Sub 

Private Sub cmdRestart_Click() 
40 txtpasswd.Text = "" 
End Sub 

Private Sub cmdQuit_Click() 
Unload password 
45 exitwnd.Show 
End Sub 

Private Sub Form_Load() 
txtpasswd.Text = "" 
50 End Sub 

Private Sub Image2_Click() 

End Sub 



55 PASSWORDFORSETTINGS FORM 

Private Sub Commandl_Click() 
If txtpasswdText = "passwordforsettings" Then 
specs.Show 
60 specs!TEXTl.Text = "" 
specs !Text2.Text = "" 
specs !Text3.Text = "" 
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specs!Text4.Text = "" 
Unload passwordforsettings 
Else 

MsgBox "Wrong Passard ! Please enter again !' 

End If 
End Sub 

Private Sub Command2_Click() 
txtpasswd.Text = "" 
End Sub 

Private Sub Command3_Click() 

Unload passwordforsettings 
exitwnd.Show 



Private Sub Form_Load() 
txtpasswd.Text = "" 
End Sub 

Private Sub Image2_Click() 
End Sub 



SETTINGS FORM 
Private Sub end_Click() 

Unload Me 
Form2.Show 

End Sub 

Private Sub Image2_Click() 
End Sub 

Private Sub Reset_Click() 

Unload Me 
specs.Show 



SPECTEST FORM 



Private Sub Commandl_Click() 
settings. Show 

settings ITextl .Text = specs ITextl. Text Height 
55 settings!Text2.Text = specs !Text2.Text W2 

settings !Text3 .Text = specs !Text3.Text Width 
settings !Text4.Text = specs !Text4.Text Wl 

The following are the Public variables 
60 Declared in the Image_Capture_Module 
'ValQ convert the string into integer 
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PattemWidth = Val(Text3.Text) 
PattemHeight = Val(Textl .Text) 
PattemWl = Val(Text4.Text) 
PatternW2 = Val(Text2.Text) 

5 

The following are the testing routines 
Height = Val(Textl.Text) 
TVIsgBox ("Height is " & Str(PattemHeight)) 
MsgBox ("Width is " & Str(PatternWidth)) 
10 TVlsgBox ("Wl is " & Str(PatternWl)) 
MsgBox ("W2 is " & Str(PatternW2)) 

Unload specs 
End Sub 

15 

Private Sub Disable_Click() 
ImageCaptureFunctionsEnable = 0 
20 End Sub 

Private Sub Enable_CIick() 
ImageCaptureFunctionsEnable = 1 

25 

End Sub 

Private Sub Image2_Click() 
30 End Sub 



IMAGE CAPTURE MODULE 

Public ImageCaptureFunctionsEnable As Integer 
3 5 Public PattemWidth, PattemHeight, PattemWl , PatternW2 As Integer 

Public Dummy Y As Integer 
Public FlagLabel As Integer 

40 -Bool 

Global Const VPP_false = 0 
Global Const VPPjxue = 1 

'Error numbers 

45 Global Const VPP_success = 0 ISo error 

Global Const VPP_toolkitInUse = 1 VideoPort toolkit is already in use 

Global Const VPP_noHardwareDetected = 2 TSTo VideoPort hardware detected 
Global Const VPP_noDriverDetected =3 No VideoPort PCMCIA driver detected 

Global Const VPP_oldVideoPortDetected = 4 The installed VideoPort is old-style 

50 Global Const VPP_notInitialized = 5 Mt has not been called 

Global Const VPP_notConfigured = 6 VideoConfig has not been called 

Global Const VPP_snapNotPrepared = 7 'prepareSnap has not been called 

Global Const VPP_snapNotStarted = 8 'startSnap has not been called 

Global Const VPP_snapNotFinished = 9 'finishSnap has not been called 

55 Global Const VPP_readoutNotStarted = 10 'startReadout has not been called 
Global Const VPP_noSignalDetected =11 T<o video signal detected 
Global Const VPP_noColorSnapped = 12 "Snapped image does not contain colour 

Global Const VPP_readoutOutsideSnappedImage =13 'Attempt to read outsize snapped im 
Global Const VPP_parameterOutOfRange = 14 Parameter to function is out of range 

60 Global Const VPP_imageWidthOutOfRange =15 Image width is out of range 
Global Const VPP_imageHeightOutOfRange = 1 6 Image height is out of range 
Global Const VPP_badPointer = 17 Bad pointer (possibly NULL) 

Global Const VPPJostContact = 1 8 "Contact with VideoPort is lost 

Global Const VPP_outOfMemory = 19 'Could not claim the memory needed 
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Global Const VPP_fileIOError = 20 Tile input/output error 

'Global constants 

Global Const VPP_DEFAULT_CHANNEL = 0 
Global Const VPP_MIN_BRIGHTNESS = -128 
Global Const VPP_MIN_CONTRAST = -128 
Global Const VPP_MIN_SATURATION = -128 
Global Const VPP_MIN_HUE = -128 
Global Const VPP_DEFAULT_BRIGHTNESS = 0 
Global Const VPP_DEFAULT_CONTRAST = 0 
Global Const VPP_DEF AULT_S ATUR ATION = 0 
Global Const VPP_DEFAULT_HUE = 0 
Global Const VPP_DEFAULT_GAMMA = 1 
Global Const VPP_MAX_BRIGHTNESS = 127 
Global Const VPP_MAX_CONTRAST = 127 
Global Const VPP_MAX_S ATUR ATION = 127 
Global Const VPP_MAX_HUE = 127 
Global Const VPP_DEFAULT_FLASH_DELAY = 8 



'Video standards 
Global Const VPP_NTSC = 0 
Global Const VPP_PAL = 1 
Global Const VPP_noSignaI = 2 

'Signal types 

Global Const VPP_composite = 0 
Global Const VPP_Svideo = 1 
Global Const VPP_monochrome = 2 



Type VPP_SnapData 

xOffset As Integer X offset of active video area 

xActive As Integer Width of active video area 

xPixels As Integer Requested width in pixels of active video area 

yOffset As Integer T offset of active video area 

yActive As Integer Height of active video area 

yPixels As Integer 'Requested height in pixels of active video area 

interlaced As Long T4ag to turn on interlaced snap 

monochrome As Long Flag to turn on monochrome snap 
End Type 



Type VPP_LimitData 
xActiveMax As Integer PAL: 922, NTSC: 754 

xPixelsMax As Integer PAL: 922, NTSC: 754, VideoPort Junior: 510 
xActiveRatio As Integer 'Currently: 14 
xPixelsRatio As Integer 'Currently: 1 
yActiveMax As Integer PAL: 610, NTSC: 510 

yPixelsMax As Integer PAL: 610, NTSC: 510, VideoPort Junior: 510 
yActiveRatio As Integer 'Currently: 14 
yPixelsRatio As Integer 'Currently: 1 
End Type 



Readout modes 'Format: Size factor: 

Global Const VPP_mono = 1 Byte I... 1 
Global Const VPP_mono4 = 2 Nibble IIII(2)... dithered 1/2 
Global Const VPP_RGB8 = 3 Byte RRRGGGBB(2)... dithered 1 
Global Const VPP_RGB15 = 4 Word 0RRRRRGG GGGBBBBB(2)... 2 
Global Const VPP_RGB16 = 5 Word RRRRRGGG GGGBBBBB(2)... 2 
Global Const VPP_BGR24 = 7 Byte B,G,R... 3 
Global Const VPP_BGR032 = 8 Byte B,G,R,0... 4 



Declare Function VPP_init Lib "VPX32.DLL" () As Long 

Declare Function VPP_closedown Lib "VPX32.DLL" (ByVal powerOff&) As Long 
Declare Function VPP_getCurrentCardHandle Lib "VPX32.DLL" (cardhandle&) As Long 
Declare Function VPP_setActiveCard Lib "VPX32.DLL" (ByVal cardhandle&) As Long 

Declare Function VPP_videoConfig Lib "VPX32.DLL" (ByVal channel%, ByVal signalType&, videoStandard&) 
As Long 
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Declare Function VPP_testSignal Lib "VPX32.DLL" (videoStandard&) As Long 
Declare Function VPP_setBrightness Lib "VPX32.DLL" (ByVal brightness%) As Long 
Declare Function VPP_setContrast Lib "VPX32.DLL" (ByVal contrast%) As Long 
Declare Function VPP_setSaturation Lib "VPX32.DLL" (ByVal saturation%) As Long 
Declare Function VPP_setHue Lib "VPX32.DLL" (ByVal hue%) As Long 
Declare Function VPP_setGamma Lib "VPX32.DLL" (ByVal gamma!) As Long 

Declare Function VPP_enableFlash Lib "VPX32.DLL" (ByVal flashSelect&, ByVal mustBeNULL&, ByVal 
flashDelay%) As Long 

Declare Function VPP_disableFlash Lib "VPX32.DLL" () As Long 

Declare Function VPP_getLimits Lib "VPX32.DLL" (ByVal videoStandard&, limitData As VPP_LimitData) As 
Long 

Declare Function VPP_prepareSnap Lib "VPX32.DLL" (snapData As VPP_SnapData) As Long 
Declare Function VPP_startSnap Lib "VPX32.DLL" () As Long 
Declare Function VPP_finishSnap Lib "VPX32.DLL" () As Long 
Declare Function VPP_flashSnap Lib "VPX32.DLL" () As Long 

Declare Function VPP_extTrigSnap Lib "VPX32.DLL" (ByVal msecTimeout%) As Long 
Declare Function VPP_autoCrop Lib "VPX32.DLL" (snapData As VPP_SnapData) As Long 



Type VPX_Config 
videoStandard As Long 
signalType As Long 
inputChannel As Long 
brightness As Long 
contrast As Long 
saturation As Long 
gamma As Single 
hue As Long 

snapDataNTSC As VPP_SnapData 
snapDataPAL As VPP_SnapData 
outputFormat As Long 
extTrigSnap As Long 
flashSnap As Long 
extTrigEnable As Long 
flashEnable As Long 
mono4Enable As Long 
monoEnable As Long 
RGB8Enable As Long 
BGR24Enable As Long 
RGB15Enable As Long 
RGB16Enable As Long 
BGR032Enable As Long 
End Type 

Type VPX_Filter 
Width As Byte 
Height As Byte 
divideBy As Long 
doAbs As Long 

The following scheme allows up to 4x4 or 3x5 filters 

coeffO As Byte Treat with care, should be "signed char" 

coeff 1 As Byte Treat with care, should be "signed char" 

coeff2 As Byte Treat with care, should be "signed char" 

coeff3 As Byte Treat with care, should be "signed char" 

coeff4 As Byte Treat with care, should be "signed char" 

coeff5 As Byte Treat with care, should be "signed char" 

coeff6 As Byte Treat with care, should be "signed char" 

coeff7 As Byte Treat with care, should be "signed char" 

coeff8 As Byte Treat with care, should be "signed char" 

coeff9 As Byte Treat with care, should be "signed char" 

coefflO As Byte Treat with care, should be "signed char" 

coeffl 1 As Byte Treat with care, should be "signed char" 

coeffl2 As Byte Treat with care, should be "signed char" 

coeffl3 As Byte Treat with care, should be "signed char" 

coeffl 4 As Byte Treat with care, should be "signed char" 

coeffl 5 As Byte Treat with care, should be "signed char" 
End Type 
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Predefined filters 

Global Const VPX_AVERAGE = 1 
Global Const VPX_SMOOTH = 2 
5 Global Const VPX_DETAIL = 3 
Global Const VPX_SHARPEN = 4 
Global Const VPX_AI = 5 
Global Const VPX_AISHARPEN = 6 
Global Const VPX_VERTLINES = 7 
10 Global Const VPX.HORIZLINES = 8 



Declare Function VPX_defaultConfig Lib "VPX32.DLL" (config As VPX_Config) As Long 
Declare Function VPX_prepare Lib "VPX32.DLL" (config As VPX_Config, By Val forceConfig&) As Long 
Declare Function VPX_snap Lib , 'VPX32.DLL" (config As VPX_Config) As Long 
15 Declare Function VPX_draw Lib "VPX32.DLL" (ByVal hDC&, config As VPX_Config, ByVal X%, ByVal Y%, 
ByVal xl%, ByVal y2%) As Long 

Declare Function VPX_drawDIB Lib "VPX32.DLL" (ByVal hDC&, ByVal hDIB&, ByVal X%, ByVal Y%, 
ByVal xl%, ByVal y2%) As Long 

Declare Function VPX_readoutDIB Lib "VPX32.DLL" (config As VPX_Config, hDIB&) As Long 
20 Declare Function VPX_readoutDIBToClipboard Lib "VPX32.DLL" (config As VPX_Config) As Long 
Declare Function VPX_saveDIBToClipboard Lib "VPX32.DLL" (ByVal hDIB&) As Long 
Declare Function VPX_readoutDIBToFile Lib "VPX32.DLL" (config As VPX_Config, ByVal filename$) As 
Long 

Declare Function VPX_saveDIBToFile Lib "VPX32.DLL" (ByVal hDIB&, ByVal filename$) As Long 
25 Declare Function VPX.snapAverageDIB Lib "VPX32.DLL" (config As VPX_Config, hDIB&, ByVal 
numAverage%, ByVal divideBy%) As Long 

Declare Function VPX_filterDIB Lib "VPX32.DLL" (ByVal hDIB&, Filter As VPX_Filter) As Long 
Declare Function VPX_filterDIBPredef Lib "VPX32.DLL" Alias "VPX_filterDIB" (ByVal hDIB&, ByVal 
Filter&) As Long 

30 Declare Function VPX_getFilter Lib "VPX32.DLL" (ByVal filterNo&) As Long 

Declare Function VPX_copyDIB Lib "VPX32.DLL" (ByVal hDIB&, phDIB&) As Long 

Declare Function VPX_readIniFile Lib "VPX32.DLL" (ByVal File$, ByVal section$, config As VPX_Config) As 
Long 

Declare Function VPX_saveIniFile Lib "VPX32.DLL" (ByVal File$, ByVal sectionS, config As VPX_Config) As 
35 Long 

Declare Function VPX_defaultPalette Lib "VPX32.DLL" (ByVal hDC&, ByVal monochrome&) As Long 
Declare Function VPX_releasePalette Lib "VPX32.DLL" () As Long 

Declare Function VPX_formatDialogBox Lib "VPX32.DLL" (ByVal ignored&, ByVal parent&, config As 
VPX_Config) As Long 

40 

Sub Check(ret As Integer) 
If ret o VPP_success Then 
MsgBox "Error returned from VPPTOOLS: " + Chr$(10) + VPP_errorString(ret), MB_OK + 
MB_ICONSTOP, "Test application" 
45 ret = VPP_closedown(VPP_trae) 

End 
End If 
End Sub 



50 Function VPP_errorString(errno As Integer) As String 
Select Case errno 
Case VPP_success 

VPP_errorString = "No error" 
Case VPP_toolkitInUse 
55 VPP_errorString = "VideoPort toolkit is already in use" 

Case VPP_noHardwareDetected 

VPP_errorString = "No VideoPort hardware detected" 
Case VPP_noDriverDetected 
VPP_errorString = "No VideoPort PCMCIA driver detected" 
60 Case VPP_oldVideoPortDetected 

VPP_errorString = "The installed VideoPort is old-style" 
Case VPP_notInitialized 

VPP_errorString = "init has not been called" 
Case VPP_notConfigured 
65 VPP_errorString = "videoConfig has not been called" 

Case VPP_snapNotPrepared 
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VPP_errorString = "prepareSnap has not been called" 
Case VPP_snapNotStarted 

VPP_errorString = "startSnap has not been called" 
Case VPP_snapNotFinished 
5 VPP_errorString = "fmishSnap has not been called" 

Case VPP_readoutNotStarted 

VPP_errorString = "startReadout has not been called" 
Case VPP_noSignalDetected 
VPP_errorString = "No video signal detected" 
10 Case VPP_noColorSnapped 

VPP_errorString = "Snapped image does not contain colour" 
Case VPP_readoutOutsideSnappedImage 

VPP_errorString = "Attempt to read outsize snapped image" 
Case VPP_parameterOutOfRange 
1 5 VPP_errorString = "Parameter to function is out of range" 

Case VPP_imageWidthOutOfRange 

VPP_errorString = "Image width is out of range" 
Case VPP_imageHeightOutOfRange 
VPP_errorString = "Image height is out of range" 
20 Case VPP_badPointer 

VPP_errorString = "Bad pointer (possibly NULL)" 
Case VPP_lostContact 

VPP_errorString = "Contact with VideoPort is lost" 
Case VPP_outOfMemory 
25 VPP_errorString = "Out of memory" 

Case VPP_fileIOError 

VPP_errorString = "File I/O error" 
Case Else 
VPP_errorString = "Unknown error" 
30 End Select 
End Function 

Public Function Mean(X As Integer, Y As Integer) 



35 

End Function 

Public Function Center_Point(X As Integer, Y As Integer) 

40 

End Function 



NIDA032 MODULE 

45 

************** ************************************************************* 

Declare Function AI_Change_Parameter% Lib "nidaq32.dll" (ByVal a%, By Val b%, ByVal c&, ByVal d&) 
Declare Function AI_Check% Lib "nidaq32.dll" (ByVal a%, b%, c%) 
Declare Function AI_Clear% Lib "nidaq32.dll" (ByVal a%) 
50 Declare Function AI_Configure% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%, 
ByVal f%) 

Declare Function AI_Mux_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%) 
Declare Function AI_Read% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, d%) 
Declare Function AI_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
5 5 Declare Function AI_VRead% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, d#) 

Declare Function AI_VScale% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d#, ByVal e#, ByVal 
f%, g#) 

Declare Function Align_DMA_Buffer% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c As Any, ByVal d&, ByVal 
e&, f&) 

60 Declare Function AO_Calibrate% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 

Declare Function AO_Configure% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e#, 
ByVal f%) 

Declare Function AO_Change_Parameter% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c&, ByVal d&) 
Declare Function AO_Update% Lib "nidaq32.dll" (ByVal a%) 
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Declare Function AO_VWrite% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c#) 
Declare Function AO_Write% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function Calibrate_E_Series% Lib "nidaq32.dll" (ByVal a.%, ByVal b&, ByVal c&, ByVal d#) 
Declare Function Calibrate_59xx% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c#) 
5 Declare Function Calibrate_DSA% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c#) 

Declare Function Config_Alarm_Deadband% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c$, ByVal d#, 
ByVal e#, ByVal f%, ByVal g%, ByVal h%, ByVal i&) 

Declare Function Config_ATrig_Event_Message% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c$, ByVal d#, 
ByVal e#, ByVal f%, ByVal g&, ByVal h&, ByVal i&, ByVal j%, ByVal k%, ByVal 1&) 
10 Declare Function Config_DAQ_Event_Message% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c$, ByVal 
d%, ByVal e&, ByVal f&, ByVal g&, ByVal h&, ByVal i&, ByVal j%, ByVal k%, ByVal 1&) 
Declare Function Configure_HW_Analog_Trigger% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&, ByVal 
d&, ByVal e&, ByVal f&) 

Declare Function CTR_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%, 
15 ByVal f%) 

Declare Function CTR_EvCount% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%, ByVal d%) 
Declare Function CTR_EvRead% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, d%) 

Declare Function CTR_FOUT_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal 

e%) 

20 Declare Function CTR_Period% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 

Declare Function CTR_Pulse% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%) 

Declare Function CTR_Rate% Lib "nidaq32.dll" (ByVal a#, ByVal b#, c%, d%, e%) 

Declare Function CTR_Reset% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 

Declare Function CTR_Restart% Lib "nidaq32.dll" (ByVal a%, ByVal b%) 
25 Declare Function CTR_Simul_Op% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, ByVal d%) 

Declare Function CTR_Square% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%) 

Declare Function CTR_State% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, c%) 

Declare Function CTR_Stop% Lib "nidaq32.dll" (ByVal a%, ByVal b%) 

Declare Function DAQ_Check% Lib "nidaq32.dll" (ByVal a.%, b%, c&) 
30 Declare Function DAQ_Clear% Lib "nidaq32.dll" (ByVal a%) 

Declare Function DAQ_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 

Declare Function DAQ_DB_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%) 

Declare Function DAQ_DB_HalfReady% Lib "nidaq32.dU" (ByVal b%, c%) 

Declare Function DAQ_DB_Transfer% Lib "nidaq32.dll" (ByVal a.%, b As Any, c&, d%) 
35 Declare Function DAQ_Monitor% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%, ByVal d&, e As Any, f&, 

g%) 

Declare Function DAQ_Op% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, d As Any, ByVal e&, ByVal 

f#) 

Declare Function DAQ_Rate% Lib "nidaq32.dll" (ByVal a#, ByVal b%, c%, d%) 
40 Declare Function DAQ_Start% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%, d As Any, ByVal e&, ByVal 
f%, ByVal g%) 

Declare Function DAQ_StopTrigger_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c&) 
Declare Function DAQ_to_Disk% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d$, ByVal e&, 
ByVal f#, ByVal g%) 

45 Declare Function DAQ_VScale% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d#, ByVal e#, 
ByVal f&, g%, h#) 

Declare Function DIG_Block_Check% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c&) 
Declare Function DIG_Block_Clear% Lib "nidaq32.dll" (ByVal a%, ByVal b%) 
Declare Function DIG_Block_In% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c As Any, ByVal d&) 
50 Declare Function DIG_Block_Out% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c As Any, ByVal d&) 

Declare Function DIG_Block_PG_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, 
ByVal e%, ByVal f%, ByVal g%) 

Declare Function DIG_DB_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%) 
Declare Function DIG_DB_HalfReady% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%) 
55 Declare Function DIG_DB_Transfer% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, c As Any, ByVal d&) 

Declare Function DIG_Grp_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%) 
Declare Function DIG_Grp_Mode% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%, 
ByVal f%, ByVal g%) 

Declare Function DIG_Grp_Status% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%) 

60 Declare Function DIG_In_Grp% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, c%) 

Declare Function DIG_In_Line% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, d%) 
Declare Function DIG_In_Port% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%) 
Declare Function DIG_Line_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%) 
Declare Function DIG_Out_Grp% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%) 

65 Declare Function DIG_Out_Line% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%) 
Declare Function DIG_Out_Port% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%) 
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Declare Function DIG_Prt_Config% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%, ByVal d%) 
Declare Function DIG_Prt_Status% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%) 

Declare Function DIG_SCAN_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, d%, ByVal e%) 
Declare Function Get_DAQ_Device_Info% Lib "nidaq32.dll" (ByVal a%, ByVal b&, c&) 
5 Declare Function Get_DAQ_Event% Lib "nidaq32.dll" (ByVal a&, b%, c%, d%, e&) 
Declare Function Get_NI_DAQ_Version% Lib "nidaq32.dll" (a&) 

Declare Function GPCTR_Config_Buffer% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&, ByVal d&, e As 
Any) 

Declare Function GPCTR_Read_Buffer% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&, ByVal d&, ByVal 

10 e&, ByVal f#, g&, h&) 

Declare Function Line_Change_Attribute% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&, ByVal d&) 
Declare Function GPCTR_Control% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&) 
Declare Function GPCTR_Set_Application% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&) 
Declare Function GPCTR_Watch% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&, d&) 

1 5 Declare Function ICTR_Read% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%) 

Declare Function ICTR_Reset% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 

Declare Function ICTR_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%) 

Declare Function Init_DA_Brds% Lib "nidaq32.dH" (ByVal a%, b%) 

Declare Function Lab_ISCAN_Check% Lib "nidaq32.dll" (ByVal a%, b%, c&, d%) 

20 Declare Function Lab_ISCAN_Op% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, d As Any, ByVal e&, 
ByVal f#, ByVal g#, h%) 

Declare Function Lab_ISCAN_Start% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, d As Any, ByVal e&, 
ByVal f%, ByVal g%, ByVal h%) 

Declare Function Lab_ISCAN_to_Disk% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d$, ByVal 

25 e&, ByVal f#, ByVal g#, ByVal h%) 

Declare Function LPM16_Calibrate% Lib "nidaq32.dll" (ByVal a%) 
Declare Function MIO_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function Peek_DAQ_Event% Lib "nidaq32.dll" (ByVal a&, b%, c%, d%, e&) 
Declare Function REG_Level_Read% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c&) 

30 Declare Function REG_Level_Write% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c&, ByVal d&, e&) 
Declare Function RTSI_Clear% Lib "nidaq32.dll" (ByVal a%) 

Declare Function RTSI_Clock% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function RTSI_Conn% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%) 
Declare Function RTSI_DisConn% Lib "nidaq32.dll" (ByVal ByVal b%, ByVal c%) 
3 5 Declare Function SC_2040_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function SCAN_Demux% Lib "nidaq32.dll" (a%, ByVal b&, ByVal c%, ByVal d%) 
Declare Function SCAN_Op% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, d%, e As Any, ByVal f&, ByVal g#, 
ByVal h#) 

Declare Function SCAN_Sequence_Demux% Lib "nidaq32.dll" (ByVal a%, b%, ByVal c&, d%, ByVal e%, f%, 
40 g&) 

Declare Function SCAN_Sequence_Retrieve% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%) 
Declare Function SCAN_Sequence_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, d%, e%, f%, g%) 
Declare Function SCAN_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, d%) 
Declare Function SCAN_Start% Lib "nidaq32.dll" (ByVal a%, b As Any, ByVal c&, ByVal d%, ByVal e%, 
45 ByVal f%, ByVal g%) 

Declare Function SCAN_to_Disk% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, d%, ByVal e$, ByVal f&, 
ByVal g#, ByVal h#, ByVal i%) 

Declare Function Calibrate_1200% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%, 
ByVal f%, ByVal g%, ByVal h%, ByVal i#, ByVal j#) 
50 Declare Function SCXI_AO_Write% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%, 
ByVal f#, ByVal g%, h%) 

Declare Function SCXI_Cal_Constants% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal 
e%, ByVal f%, ByVal g#, ByVal h%, ByVal i%, ByVal j%, ByVal k#, ByVal 1#, ByVal m#, ByVal n#, ByVal o#, 
p#,q#) 

55 Declare Function SCXI_Calibrate% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e%, 
ByVal f#, ByVal g#, ByVal h%, ByVal i%) 

Declare Function SCXI_Calibrate_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function SCXI_Change_Chan% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function SCXI_Set_Excitation% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal 
60 e!, f!) 

Declare Function SCXI_Configure_Connection% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal 
d%) 

Declare Function SCXI_Configure_Filter% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, 
ByVal e#, ByVal f%, ByVal g%, h#) 
65 Declare Function SCXI_Get_Chassis_Info% Lib "nidaq32.dll" (ByVal a%, b%, c%, d%, e%, f%) 

Declare Function SCXI_Get_Module_Info% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c&, d%, e%) 
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Declare Function SCXI_Get_State% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, e&) 
Declare Function SCXI_Get_Status% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, d&) 
Declare Function SCXI_Load_Config% Lib "nidaq32.dll" (ByVal a%) 

Declare Function SCXI_MuxCtr_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%) 
5 Declare Function SCXI_Reset% Lib "nidaq32.dll" (ByVal a%, ByVal b%) 

Declare Function SCXI_Scale% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%, ByVal d#, ByVal e# ByVal 
f%, ByVal g%, ByVal h%, ByVal i&, j%, k#) 

Declare Function SCXI_SCAN_Setup% Lib "nidaq32.dH" (ByVal a%, ByVal b%, c%, d%, e%, ByVal f% ByVal 

g%) 

10 Declare Function SCXI_Set_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d% ByVal 
e%, ByVal f%, g&, h%, i%) 

Declare Function SCXI_Set_Gain% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d#) 
Declare Function SCXI_Set_Input_Mode% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function SCXI_Set_State% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%, ByVal e&) 
15 Declare Function SCXI_Single_Chan_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%> ByVal d%) 
Declare Function SCXI_Track_Hold_Control% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d%) 
Declare Function SCXI_Track_Hold_Setup% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%, ByVal d% 
ByVal e%, ByVal f%, ByVal g%) 

Declare Function Select_Signal% Lib "nidaq32.dll" (ByVal a.%, ByVal b&, ByVal c&, ByVal d&) 
20 Declare Function Set_DAQ_Device_Info% Lib "nidaq32.dH" (ByVal a%, ByVal b&, ByVal c&) 
Declare Function Timeout_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b&) 
Declare Function WFM_Chan_Control% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function WFM_Check% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, d&, e&) 

Declare Function WFM_ClockRate% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%, ByVal d%, ByVal e& 
25 ByVal f%) 

Declare Function WFM_DB_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, ByVal d%, ByVal e% 
ByVal f%) 

Declare Function WFM_DB_HalfReady% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, c%, d%) 
Declare Function WFM_DB_Transfer% Lib "nidaq32.dir' (ByVal a%, ByVal b%, c%, d As Any, ByVal e&) 
30 Declare Function WFM_from_Disk% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, ByVal d$ ByVal e& ByVal 
f&, ByVal g&, ByVal h#) 

Declare Function WFM_Group_Control% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%) 
Declare Function WFM_Group_Setup% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, ByVal d%) 
Declare Function WFM_Load% Lib "mdaq32.dll" (ByVal a%, ByVal b%, c%, d As Any, ByVal e& ByVal f& 
35 ByVal g%) 

Declare Function WFM_Op% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c%, d As Any, ByVal e& ByVal f& 
ByVal g#) 

Declare Function WFM_Rate% Lib "nidaq32.dll" (ByVal a#, ByVal b%, c%, d&) 

Declare Function WFM_Scale% Lib "nidaq32.dU" (ByVal a.%, ByVal b%, ByVal c&, ByVal d#, e#, f%) 
40 Declare Function AI_Read_Scan% Lib "nidaq32.dll" (ByVal a%, b%) 

Declare Function AI_VRead_Scan% Lib "nidaq32.dll" (ByVal a%, b#) 

Declare Function SCXI_ModuleID_Read% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c&) 

Declare Function USE_E_Series% Lib "nidaq32.dll" {) 

Declare Function USE_E_Series_AI% Lib "nidaq32.dll" () 
45 Declare Function USE_E_Series_AO% Lib "nidaq32.dll" () 

Declare Function USE_E_Series_DIO% Lib "nidaq32.dll" () 

Declare Function USE_E_Series_GPCTR% Lib "nidaq32.dll" () 

Declare Function USE_E_Series_GPCTR_Simple% Lib "nidaq32.dll" () 

Declare Function USE_E_Series_Misc% Lib "nidaq32.dll" () 
50 Declare Function USE_E_Series_WFM% Lib "nidaq32.dll" () 

Declare Function AO_VScale% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c#, d%) 

Declare Function GPCTR_Change_Parameter% Ub "nidaq32.dll" (ByVal a%, ByVal bt&, ByVal c&, ByVal d&) 

Declare Function USE_E_Series_DAQ% Lib "nidaq32.dll" () 

Declare Function USE_MIO% Lib "nidaq32.dll" () 
55 Declare Function USE_LPM% Lib "nidaq32.dll" () 

Declare Function USE_LAB% Lib "nidaq32.dll" () 

Declare Function USE_DIO_96% Lib "nidaq32.dll" () 

Declare Function USE_DIO_32F% Lib "nidaq32.dll" () 

Declare Function USE_DIO_24% Lib "nidaq32.dll" () 
60 Declare Function USE_AO_610% Lib "nidaq32.dll" () 

Declare Function USE_AO_2DC% Lib "nidaq32.dH" () 

Declare Function DIG_Trigger_Config% Lib "nidaq32.dll" (ByVal a.%, ByVal b%, ByVal c%, ByVal d% ByVal 
e%, ByVal f%, ByVal g&, ByVal h&, ByVal i&) 

Declare Function SCXI_Set_Threshold% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c%, ByVal d#, ByVal 
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Declare Function WFM_Set_Clock% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c&, ByVal d#, ByVal e& 
f#) 

Declare Function DAQ_Set_Clock% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c#, ByVal d&, e#) 
Declare Function Tio_Select_Signal% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&, ByVal d&) 
5 Declare Function Tio_Combine_Signals% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&) 
Declare Function DIG_InJPrt% Lib "nidaq32.dll" (ByVal a%, ByVal b%, c&) 
Declare Function DIG_Out_Prt% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c&) 
Declare Function AI_Get_Overloaded_Channels% Lib "nidaq32.dll" (ByVal a%, b%, c%) 
Declare Function Calibrate_TIO% Lib "nidaq32.dll" (ByVal a%, ByVal b&, ByVal c&, ByVal d#) 
10 Declare Function DIG_Change_Message_Config% Lib "nidaq32.dll" (ByVal a%, ByVal b%, ByVal c$ BvVal 
d$, ByVal e%, ByVal f%, ByVal g&) 

Declare Function DIG_Change_Message_Control% Lib "nidaq32.dll" (ByVal a%, ByVal b%) 
Declare Function DIG_Filter_Config% Lib "mdaq32.dll" (ByVal a%, ByVal b%, ByVal c$, ByVal d#) 



15 NIDAOCNS.INC MODULE 

>********************* 

** This file contains definitions for constants required for some *' 
20 * of the NI-DAQ functions. *' 

* You should use symbols defined here in your programs; do not *' 
use the numerical values. *' 

25 ** See your NI-DAQ Function Reference Manual for details concerning *' 
** use of constants defined here. *' 

Global Const ND_ABOVE_HIGH_LEVEL& = 11020 

30 Global Const ND_AC& = 1 1025 

Global Const ND_ACK_REQ_EXCHANGE_GR1 & =11030 
Global Const ND_ACK_REQ_EXCHANGE_GR2& =11035 
Global Const ND_ACTIVE& = 11037 
Global Const ND_ADC_RESOLUTION& = 11040 

35 Global Const ND_AI_CALDAC_COUNT& = 1 1050 
Global Const ND_AI_CHANNEL_COUNT& =11060 
Global Const ND_AI_COUPLING& = 1 1055 
Global Const ND_AI_FIFO_INTERRUPTS& = 1 1600 
Global Const ND_ANALOG_FILTER& = 11065 

40 Global Const ND_A048XDC_SET_POWERUP_STATE& = 42 100 
Global Const ND_AO_CALDAC_COUNT& =11070 
Global Const ND_AO_CHANNEL_COUNT& = 11080 
Global Const ND_AO_EXT_REF_CAPABLE& = 1 1090 
Global Const ND_AO_UNIPOLAR_CAPABLE& = 1 1095 

4 5 Global Const ND_ARM& = 1 1 1 00 

Global Const ND„ARMED& = 1 1200 

Global Const ND_ATC_OUT& = 11250 

Global Const ND_ATTENUATION& = 1 1260 

Global Const ND_AUTOINCREMENT_COUNT& = 1 1 300 

50 Global Const ND_AUTOMATIC& = 1 1400 

Global Const ND_AVAILABLE_POINTS& = 1 1500 

Global Const ND_B AS E_ADDRESS & = 12100 
Global Const ND_BELOW_LOW_LEVEL& = 12130 

55 Global Const ND_BOARD_CLOCK& = 12170 

Global Const ND_BUFFERED_EVENT_CNT& = 12200 
Global Const ND_BUFFERED_PERIOD_MSR& = 12300 
Global Const ND_BUFFERED_PULSE_WIDTH_MSR& = 12400 
Global Const ND_BUFFERED_SEMI_PERIOD_MSR& = 12500 

60 Global Const ND_BURST& = 12600 

Global Const ND_BURST_INTERVAL& = 12700 

Global Const ND_CAL_CONST_AUTO_LOAD& = 13050 
Global Const ND_CALIBRATION_ENABLE& = 13055 
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Global Const ND_CALIBRATION_FRAME_SIZE& = 13060 
Global Const ND_CALIBRATION_FRAME_PTR& = 13065 
Global Const ND_CJ_TEMP% = &H8000 
Global Const ND_C ALGND % = &H8001 
5 Global Const ND_CLEAN_UP& = 1 3 100 

Global Const ND_CLOCK_REVERSE_MODE_GRl&= 13120 
Global Const ND_CLOCK_REVERSE_MODE_GR2& = 13130 
Global Const ND_CONFIG_MEMORY_SIZE& =13150 
Global Const ND_CONTINUOUS& =13160 
10 Global Const ND_COUNT& = 13200 

Global Const ND_COUNTER_0& = 13300 
Global Const ND_COUNTER_l& = 13400 
Global Const ND_COUNTER_2& = 13310 
1 5 Global Const ND_COUNTER_3& = 1 3320 
Global Const ND_COUNTER_4& = 13330 
Global Const ND_COUNTER_5& = 13340 
Global Const ND_COUNTER_6& = 13350 
Global Const ND_COUNTER 7& = 13360 

20 

Global Const ND_COUNTER_l_SOURCE& = 13430 
Global Const ND_COUNT_AVAILABLE& = 13450 
Global Const ND_COUNT_DOWN& = 13465 
Global Const ND_COUNT_UP& = 13485 
25 Global Const ND_COUNT_l & = 13500 
Global Const ND_COUNT_2& = 13600 
Global Const ND_COUNT_3& = 13700 
Global Const ND_COUNT_4& = 13800 
Global Const ND_CURRENT OUTPUT& = 40200 

30 

Global Const ND_DAC_RESOLUTION& = 13950 
Global Const ND_D AT A_TRANSFER_CONDITION& = 13960 
Global Const ND_DATA_XFER_MODE_AI& = 14000 
Global Const ND_DATA_XFER_MODE_AO_GRl& = 14100 

35 Global Const ND_DATA_XFER_MODE_AO_GR2& = 1 4200 
Global Const ND_DATA_XFER_MODE_DIO_GRl&= 14300 
Global Const ND_DATA_XFER_MODE_DIO_GR2& = 14400 
Global Const ND_DAT A_XFER_MODE_DIO_GR3 & = 14500 
Global Const ND_DATA_XFER_MODE_DIO_GR4& = 14600 

40 Global Const ND_DATA_XFER_MODE_DIO_GR5& = 14700 
Global Const ND_DATA_XFER_MODE_DIO_GR6& = 14800 
Global Const ND_DATA_XFER_MODE_DIO_GR7& = 14900 
Global Const ND_DATA_XFER_MODE_DIO_GR8& = 15000 

45 Global Const ND_DATA_XFER_MODE_GPCTR0& = 15 100 
Global Const ND_DAT A_XFER_MODE_GPCTR 1 & = 15200 
Global Const ND_DATA_XFER_MODE_GPCTR2& =15110 
Global Const ND_D AT A_XFER_MODE_GPCTR3 & = 15120 
Global Const NDDATA_XFER_MODE_GPCTR4& = 15130 

50 Global Const ND_DATA_XFER_MODE_GPCTR5& = 15 140 
Global Const ND_DATA_XFER_MODE_GPCTR6& =15150 
Global Const ND_DATA_XFER_MODE_GPCTR7& = 15160 
Global Const ND_DATA_XFER_MODE_GPCTR8& = 15165 
Global Const ND_DATA_XFER_MODE_GPCTR9& = 15 1 70 

55 Global Const ND_DATA_XFER_MODE_GPCTR10& = 15175 
Global Const ND_DATA_XFER_MODE_GPCTR 1 1 & = 15180 

Global Const ND_DC& = 15250 

Global Const ND_DDS_BUFFER_SIZE& = 15255 
60 Global Const ND_DEVICE_NAME& = 15260 

Global Const ND_DEVICE_POWER& = 15270 

Global Const ND_DEVICE_SERIAL_NUMBER& = 15280 

Global Const ND_DEVICE_STATE_DURING_SUSPEND_MODE& = 15290 

Global Const ND_DEVICE_TYPE_CODE& = 15300 
65 Global Const ND_DIGITAL_FILTER& = 15350 

Global Const ND_DIGITAL_RESTART& = 15375 
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Global Const ND_DI0128_GET„PORT_THRESHOLD& = 41200 
Global Const ND_DI0128_SELECT_INPUT_PORT& = 41 100 
Global Const ND_DI0128_SET_PORT_THRESHOLD& = 41300 
Global Const ND_DISABLED& = 15400 
5 Global Const ND.DISARM& = 15450 

Global Const ND_DIVIDE_DOWN_SAMPLING_SUPPORTED& = 15475 
Global Const ND_DMA_A_LEVEL& = 15500 
Global Const ND_DMA_B_LEVEL& = 15600 
Global Const ND_DMA_C_LEVEL& = 15700 
1 0 Global Const ND_DONE& =15800 

Global Const NDJDONT.CARE& = 15900 
Global Const ND_DONT_KNOW& = 15950 

Global Const ND_EDGE_SENS ITI V E& = 16000 
15 Global Const NDJENABLED& = 16050 
Global Const NDJEND& = 16055 
Global Const ND_EXTERNAL& = 16060 
Global Const ND_EXTERNAL_CALIBRATE& = 16100 

20 Global Const ND_F ACTOR Y_CALIBRATION_EQUIP& = 16210 
Global Const ND_F ACTOR Y_EEPROM_AREA& = 16220 
Global Const ND_FIFO_EMPTY& = 16230 
Global Const ND_FIFO_HALF_FULL_OR_LESS& = 16240 
Global Const ND_FIFO_HALF_FULL_OR_LESS_UNTIL_FULL& = 1 6245 

25 Global Const ND_FIFO_NOT_FULL& = 16250 

Global Const ND_FIFO_TRANSFER_COUNT& = 16260 
Global Const ND_FILTER_CORRECTION_FREQ& = 16300 
Global Const NDJFOREGROUND& = 16350 
Global Const ND_FREQ_OUT& = 16400 

30 Global Const ND.FSK& = 1 6500 

Global Const ND_EDGE_BASED_FSK& = 16500 

Global Const ND_GATE& =17100 

Global Const ND.GATE POLARITY& = 17200 

35 

Global Const ND_GPCTR0_GATE& = 17300 
Global Const ND_GPCTR0_OUTPUT& = 17400 
Global Const ND_GPCTR0_SOURCE& = 17500 

40 Global Const ND_GPCTR1_GATE& = 17600 

Global Const ND_GPCTRl_OUTPUT& = 17700 
Global Const ND_GPCTRl_SOURCE& = 17800 

Global Const ND_GPCTR2_GATE& = 17320 
45 Global Const ND_GPCTR2_OUTPUT& = 17420 
Global Const ND_GPCTR2_SOURCE& = 17520 

Global Const ND_GPCTR3_GATE& = 17330 
Global Const ND_GPCTR3_OUTPUT& = 17430 
50 Global Const ND_GPCTR3_SOURCE& = 17530 

Global Const ND_GPC TR4_G ATE& = 17340 
Global Const ND_GPCTR4_OUTPUT& = 17440 
Global Const ND_GPCTR4_SOURCE& = 17540 

Global Const ND_GPCTR5_GATE& = 17350 
Global Const ND_GPCTR5_OUTPUT& = 17450 
Global Const ND_GPCTR5_SOURCE& = 17550 

60 Global Const ND_GPCTR6_GATE& = 1 7360 

Global Const ND_GPCTR6_OUTPUT& = 17460 
Global Const ND_GPCTR6_SOURCE& = 17660 

Global Const ND_GPCTR7_GATE& = 17370 
65 Global Const ND_GPCTR7_OUTPUT& = 17470 
Global Const ND_GPCTR7_SOURCE& = 17570 
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Global Coast ND_GROUND_DAC_REFERENCE& = 17900 



Global Const ND_HARDWARE& = 18000 

Global Const ND_HI_RES_SAMPLING& = 18020 

Global Const ND_HIGH& = 18050 

Global Const ND_HIGH_HYSTERESIS& = 18080 

Global Const ND_HIGH_TO_LOW& = 18100 

Global Const ND_HW_ANALOG_TRIGGER& = 18900 

Global Const ND_1MPEDANCE& = 19000 

Global Const ND_INACTIVE& = 19010 

Global Const ND_INITIAL_COUNT& = 19100 

Global Const ND_INIT_PLUGPLAY_DEVICES& = 191 10 

Global Const ND_INSIDE_REGION& = 19150 

Global Const ND.INTERNAL& = 19160 

Global Const NDJNTERN AL_ 1 00_KHZ& = 19200 

Global Const ND_INTERNAL_10_MHZ& = 19300 

Global Const ND_INTERNAL_1250_KHZ& = 19320 

Global Const ND_INTERNAL_20_MHZ& = 19400 

Global Const ND_INTERNAL_25_MHZ& = 19410 

Global Const ND_INTERNAL_2500_KHZ& = 19420 

Global Const ND_INTERNAL_5_MHZ& = 19450 

Global Const ND_INTERNAL_7160_KHZ& = 19460 

Global Const ND_INTERNAL_TIMER& = 19500 

Global Const ND_INTERRUPTS& = 19600 

Global Const ND_INTERRUPT_A_LEVEL& = 19700 

Global Const ND_INTERRUPT_B_LEVEL& = 19800 

Global Const ND_INTERRUPT_TRIGGER_MODE& = 19850 

Global Const ND_IN_CHANNEL_CLOCK_TIMEB ASE& = 19900 

Global Const ND_IN_CHANNEL_CLOCK_TB_POL& = 20000 

Global Const ND_IN_CONVERT& = 20100 

Global Const ND_IN_CONVERT_POL& = 20200 

Global Const ND_IN_DATA_FIFO_SIZE& = 20250 

Global Const ND_IN_EXTERNAL_GATE& = 20300 

Global Const ND_IN_EXTERNAL_GATE_POL& = 20400 

Global Const ND_IN_SCAN_CLOCK_TIMEBASE& = 20500 

Global Const ND_IN_SCAN_CLOCK_TB_POL& = 20600 

Global Const ND_IN_SCAN_IN_PROG& = 20650 

Global Const ND_IN_SCAN_START& = 20700 

Global Const ND_IN_SCAN_START_POL& = 20800 

Global Const ND_IN_START_TRIGGER& = 20900 

Global Const ND_IN_START_TRIGGER_POL& =21000 

Global Const ND_IN_STOP_TRIGGER& = 21 100 

Global Const ND_IN_STOP_TRIGGER_POL& = 21200 

Global Const ND_INT_AI_GND& = 21210 

Global Const ND_INT_AO_CH_0& = 21230 

Global Const ND_INT_AO_CH_0_VS_REF_5V& = 21235 

Global Const ND_INT_AO_CH_l & = 21240 

Global Const ND_INT_AO_CH_1_VS_AO_CH_0& = 21245 

Global Const ND_INT_AO_CH_l_VS_REF_5V& = 21250 

Global Const NDJNT_AO_CH_2& = 21220 

Global Const ND_INT_AO_CH_3& = 21221 

Global Const ND_INT_AO_CH_4& = 21222 

Global Const ND_INT_AO_CH_5& = 21223 

Global Const ND_INT_AO_CH_6& = 21224 

Global Const ND_INT_AO_CH_7& = 21225 

Global Const ND_INT_AO_GND& = 21260 

Global Const ND_INT_AO_GND_VS_AI_GND& = 21265 

Global Const ND_INT_CM_REF_5V& = 21270 

Global Const ND_INT_DEV_TEMP& = 21280 

Global Const ND_INT_REF_5V& = 21290 
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Global Const ND_INT_REF_EXTERN& = 21296 
Global Const ND_INT_CAL_BUS& = 21295 
Global Const ND_INT_MUX_BUS& = 21305 

5 Global Const ND_INT_AI_GND_AMP_0& = 21211 
Global Const ND_INT_AI_GND_AMP_1& = 21212 
Global Const ND_INT_AI_GND_AMP_2& = 21213 
Global Const ND_INT_AI_GND_AMP_3& = 21214 
Global Const ND_INT_AO_CH_0_AMP_0& = 21231 

10 Global Const ND_INT_AO_CH_0_AMP_1& = 21232 
Global Const ND_INT_AO_CH_0_AMP_2& = 21233 
Global Const ND_INT_AO_CH_0_AMP_3& =21234 
Global Const ND_INT_AO_CH_1_AMP_0& = 21241 
Global Const ND_INT_AO_CH_l_AMP_l& = 21242 

1 5 Global Const ND_INT_AO_CH_l_AMP_2& = 2 1 243 
Global Const ND_INT_AO_CH_l_AMP_3& = 21244 
Global Const ND_INT_AO_CH_0_VS_REF_AMP_0& = 21236 
Global Const ND_INT_AO_CH_0_VS_REF_AMP_1& = 21237 
Global Const ND_INT_AO_CH_0_VS_REF_AMP_2& = 21238 

20 Global Const ND_INT_AO_CH_0_VS_REF_AMP_3& = 2 1 239 
Global Const ND_INT_AO_CH_1_VS_REF_AMP_0& = 21251 
Global Const ND_INT_AO_CH_l_VS_REF_AMP_l& =21252 
Global Const ND_INT_AO_CH_l_VS_REF_AMP_2& = 21253 
Global Const ND_INT_AO_CH_l_VS_REF_AMP_3& = 21254 

25 Global Const ND_INT_AO_GND_VS_AI_GND_AMP_0& = 21266 
Global Const ND_INT_AO_GND_VS_AI_GND_AMP_l& = 21267 
Global Const ND_INT_AO_GND_VS_AI_GND_AMP_2& = 21268 
Global Const ND_INT_AO_GND_VS_AI_GND_AMP_3& = 21269 
Global Const ND_INT_CM_REF_AMP_0& = 21271 

30 Global Const ND_INT_CM_REF_AMP_1& = 21272 
Global Const ND_INTCM_REF_AMP_2& = 21273 
Global Const ND_INT_CM_REF_AMP_3& = 21274 
Global Const ND_INT_REF_AMP_0& = 21291 
Global Const ND_INT_REF_AMP_1 & = 21292 

35 Global Const ND_INT_REF_AMP_2& = 21293 
Global Const ND_INT_REF_AMP_3 & = 21294 

Global Const ND_INTERRUPT_EVERY_SAMPLE& = 11700 
Global Const ND_INTERRUPT_HALF_FIFO& =11800 
40 Global Const ND_IO_CONNECTOR& = 21300 

Global Const ND_LEVEL_SENSITIVE& = 24000 
Global Const ND_LINK_COMPLETE_INTERRUPTS& = 24010 
Global Const ND_LOW& = 24050 
45 Global Const ND_LOW_HYSTERESIS& = 24080 
Global Const ND_LOW_TO_HIGH& = 24100 
Global Const ND_LPT_DEVICE_MODE& = 24200 

Global Const ND_MARKER& = 24500 
50 Global Const ND_MARKER_QUANTUM& = 24550 

Global Const ND_MAX_ARB_SEQUENCE_LENGTH& = 24600 
Global Const ND_MAX_FUNC_SEQUENCE_LENGTH& = 24610 
Global Const ND_MAX_LOOP_COUNT& = 24620 
Global Const ND_MAX_NUM_WAVEFORMS& = 24630 
55 Global Const ND_MAX_SAMPLE_RATE& = 24640 
Global Const ND_MAX_WFM_SIZE& = 24650 
Global Const ND_MEMORY_TRANSFER_WEDTH& = 24700 
Global Const ND_MIN_SAMPLE_RATE& = 24800 
Global Const ND_MIN_WFM SIZE& = 24810 

60 

Global Const ND_NEGATTVE& = 26100 
Global Const ND_NEW& = 26190 
Global Const ND_NI_DAQ_SW_AREA& = 26195 
Global Const ND_NO& = 26200 
65 Global Const ND_NO_STRAIN_GAUGE& = 26225 

Global Const ND_NO_TRACK_AND_HOLD& = 26250 
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Global Const ND_NONE& = 26300 

Global Const ND_NOT_APPLICABLE& = 26400 

Global Const ND_NUMBER_DIG_PORTS& = 26500 

5 Global Const ND.OFF& = 2701 0 

Global Const ND_OFFSET& = 27020 

Global Const ND_ON& = 27050 

Global Const ND.OTHER& = 27060 

Global Const ND_OTHER_GPCTR_OUTPUT& = 27300 

1 0 Global Const ND_OTHER_GPCTR_TC& = 27400 

Global Const ND_OUT_DATA_FIFO_SIZE& = 27070 
Global Const ND_OUT_EXTERNAL_GATE& = 27080 
Global Const ND_OUT_EXTERNAL_GATE_POL& = 27082 
Global Const ND_OUT_START_TRIGGER& = 27100 

1 5 Global Const ND_OUT_START_TRIGGER_POL& = 27 1 02 
Global Const ND_OUT_UPDATE& = 27200 
Global Const ND_OUT_UPDATE_POL& = 27202 
Global Const ND_OUT_UPDATE_CLOCK_TIMEBASE& = 27210 
Global Const ND_OUT_UPDATE_CLOCK_TB_POL& = 27212 

20 Global Const ND_OUTPUT_ENABLE& = 27220 
Global Const ND_OUTPUT_MODE& = 27230 
Global Const ND_OUTPUT_POLARITY& = 27240 
Global Const ND_OUTPUT_STATE& = 27250 
Global Const ND_OUTPUT_TYPE& = 40000 

25 

Global Const ND_DIGITAL_PATTERN_GENERATION& = 28030 

Global Const ND_PAUSE& = 28040 

Global Const ND_PAUSE_ON_HIGH& = 28045 

Global Const ND_PAUSE_ON_LOW& = 28050 
3 0 Global Const ND_PFI_0& = 28 1 00 

Global Const ND_PFI_1& = 28200 

Global Const ND_PFI_2& = 28300 

Global Const ND_PFI_3& = 28400 

Global Const ND_PFI_4& = 28500 
3 5 Global Const ND_PFI_5& = 28600 

Global Const ND_PFI_6& = 28700 

Global Const ND_PFI_7& = 28800 

Global Const ND_PFI_8& = 28900 

Global Const ND_PFI_9& = 29000 
40 Global Const ND_PFI_10& = 50280 

Global Const ND_PFI_11& = 50290 

Global Const ND_PFI_12& = 50300 

Global Const ND_PFI_13& = 50310 

Global Const ND_PFI_14& = 50320 
45 Global Const ND_PFI_15& = 50330 

Global Const ND_PFI_16& = 50340 

Global Const ND_PFI_17& = 50350 

Global Const ND_PFI_18& = 50360 

Global Const ND_PFI_19& = 50370 
50 Global Const ND_PFI_20& = 50380 

Global Const ND_PFI_21& = 50390 

Global Const ND_PFI_22& = 50400 

Global Const ND_PFI_23& = 50410 

Global Const ND_PFI_24& = 50420 
55 Global Const ND_PFI_25& = 50430 

Global Const ND_PFI_26& = 50440 

Global Const ND_PFI_27& = 50450 

Global Const ND_PFI_28& = 50460 

Global Const ND_PFI_29& = 50470 
60 Global Const ND_PFI_30& = 50480 

Global Const ND_PFI_3 1 & = 50490 

Global Const ND_PFI_32& = 50500 

Global Const ND_PFI_33& = 50510 

Global Const ND_PFI_34& = 50520 
65 Global Const ND_PFI_35& = 50530 

Global Const ND_PFI_36& = 50540 
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Global Const ND_PFI_37& = 50550 
Global Const ND_PFI_38& = 50560 
Global Const ND_PFI_39& = 50570 

5 Global Const ND_PLL_REF_FREQ& = 29010 

Global Const ND_PLL_REF_SOURCE& = 29020 
Global Const ND_PRE_ARM& = 29050 
Global Const ND_POSITTVE& = 29100 
Global Const ND.PREPARE& = 29200 
10 Global Const NDJPROGRAM& = 29300 
Global Const ND_PULSE& = 29350 
Global Const ND_PULSE_SOURCE& = 29500 
Global Const ND_PULSE_TRAIN_GNR& = 29600 
Global Const ND_PXI_BACKPLANE CLOCK& = 29900 

15 

Global Const ND_REGLITCH& = 3 1000 

Global Const ND_RESERVED& = 31100 

Global Const ND_RESET& = 31200 

Global Const ND_RESUME& =31250 
20 Global Const ND_RETRIG_PULSE_GNR& = 31300 

Global Const ND_REVISION& = 31350 

Global Const ND_RTSI_0& = 31400 

Global Const ND_RTSI_1& = 31500 

Global Const ND_RTSI_2& = 31600 
25 Global Const ND_RTSI_3& = 31700 

Global Const ND_RTSI_4& = 31800 

Global Const ND_RTSI_5& = 31900 

Global Const ND_RTSI_6& = 32000 

Global Const ND_RTSI_CLOCK& = 32100 

30 

Global Const NDJSCANCLK& = 32400 
Global Const ND_SCANCLK_LINE& = 32420 
Global Const ND_SC_2040_MODE& = 32500 
Global Const ND_SC_2043_MODE& = 32600 

35 Global Const ND_SELF_CALIBRATE& = 32700 

Global Const ND_SET_DEFAULT_LOAD_AREA& = 32800 
Global Const ND_RESTORE_F ACTOR Y_CALIBRATION& = 32810 
Global Const ND_SET_POWERUP_STATE& = 42100 
Global Const ND_S IMPLE_EVENT_CNT& = 33100 

40 Global Const ND_SINGLE& = 33150 

Global Const ND_SINGLE_PERIOD_MSR& = 33200 
Global Const ND_S INGLE_PULSE_GNR& = 33300 
Global Const ND_SINGLE_PULSE_WIDTH_MSR& = 33400 
Global Const ND_SINGLE_TRIG_PULSE_GNR& = 33500 

45 Global Const ND_SOURCE& = 33700 

Global Const ND_SOURCE_POLARITY& = 33800 
Global Const ND_STABLE_10_MHZ& = 33810 
Global Const ND_S TEPPED& = 33825 
Global Const ND_STRAIN_GAUGE& = 33850 

50 Global Const ND_STRAIN_GAUGE_EX0& = 33875 
Global Const ND_SUB_REVISION& = 33900 
Global Const ND_SYNC_DUTY_CYCLE_HIGH& = 33930 
Global Const ND_SYNC_OUT& = 33970 

55 Global Const ND_TC_REACHED& = 34100 

Global Const ND_THE_AI_CHANNEL& = 34400 

Global Const ND_TOGGLE& = 34700 

Global Const ND_TOGGLE_GATE& = 34800 

Global Const ND_TRACK_AND_HOLD& = 34850 
60 Global Const ND_TRIG_PULSE_WEDTH_MSR& = 34900 

Global Const ND_TRIGGER_SOURCE& = 34930 

Global Const ND_TRIGGER_MODE& = 34970 

Global Const ND_UI2_TC& = 35100 
65 Global Const ND_UP_DOWN& = 35 150 

Global Const ND_UP_TO_l_DMA_CHANNEL& = 35200 
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Global Const ND_UP_TO_2_DMA_CHANNELS& = 35300 
Global Const ND_USE_CAL_CHAN& = 36000 
Global Const ND_USE_AUX_CHAN& = 36100 
Global Const ND_USER_EEPROM_AREA& = 37000 
5 Global Const ND_USER_EEPROM_AREA_2& = 37010 
Global Const ND_USER_EEPROM_ARE A_3 & = 37020 
Global Const ND_USER_EEPROM_AREA_4& = 37030 
Global Const ND_USER_EEPROM_AREA_5& = 37040 

1 0 Global Const ND_DSA_RTSI_CLOCK_AD& = 44000 

Global Const ND_DSA_RTSI_CLOCK_DA& = 44010 

Global Const ND_DSA_OUTPUT_TRIGGER& = 44020 

Global Const NDJDSAJNPUTTRIGGER& = 44030 

Global Const ND_DSA_SHARC_TRIGGER& = 44040 
1 5 Global Const ND_DS A_ANALOG_TRIGGER& = 44050 

Global Const ND_DSA_HOST_TRIGGER& = 44060 

Global Const ND_DSA_EXTERNAL_DIGITAL_TRIGGER& = 44070 

Global Const ND_VOLTAGE_OUTPUT& = 40100 
20 Global Const ND_VOLTAGE_REFERENCE& = 38000 

Global Const ND_VXI_SC% = &H2000 
Global Const ND_PXI_SC% = &H2010 

Global Const ND_VXIMIO_SET_ALLOCATE_MODE& = 43100 
25 Global Const ND_VXIMIO_USE_ONBOARD_MEMORY_AI& = 43500 
Global Const ND_VXIMIO_USE_ONBOARD_MEMORY_AO& = 43600 
Global Const ND_VXIMIO_USE_ONBOARD_MEMORY_GPCTR& = 43700 
Global Const ND_VXIMIO_USE_PC_MEMORY_AI& = 43200 
Global Const ND_VXIMIO_USE_PC_MEMORY_AO& = 43300 
3 0 Global Const ND_VXIMIO_USE_PC_MEMOR Y_GPCTR& = 43400 

Global Const ND_WFM_QUANTUM& = 45000 

Global Const ND_YES& = 39100 
3 5 Global Const ND_3 VJLEVEL& = 43450 

Global Const ND_WRITE_MARK& = 50000 
Global Const ND_READ_MARK& = 50010 
Global Const ND_BUFFER_START& = 50020 
40 Global Const ND_TRIGGER_POINT& = 50025 
Global Const ND_BUFFER_MODE& = 50030 
Global Const ND_DOUBLE& = 50050 

Global Const ND_QUADRATURE_ENCODER_Xl& = 50070 

Global Const ND_QUADRATURE_ENCODER_X2& = 50080 
45 Global Const ND_QUADRATURE_ENCODER_X4& = 50090 

Global Const ND_TWO_PULSE_COUNTING& = 50100 

Global Const ND_LINE_FBLTER& = 501 10 

Global Const ND_SYNCHRONIZATION& = 50120 

Global Const ND_5_MICROSECONDS& = 50130 
50 Global Const ND_l_MICROSECOND& = 50140 

Global Const ND_500_NANOSECONDS& = 50150 

Global Const ND_100_NANOSECONDS& = 50160 

Global Const ND_l_MILLISECOND& = 50170 

Global Const ND_10_MILLISECONDS& = 50180 
55 Global Const ND_100_MILLISECONDS& = 50190 



Global Const ND_OTHER_GPCTR_SOURCE& = 50580 

Global Const ND_OTHER_GPCTR_GATE& = 50590 
60 Global Const ND_AUX_LINE& = 50600 

Global Const ND_AUX_LINE_POLARITY& = 50610 

Global Const ND_TWO_S IGN AL_EDGE_SEP AR ATION_M SR& = 50630 

Global Const ND_BUFFERED_TWO_SIGNAL_EDGE_SEPARATION_MSR& = 50640 

Global Const ND_SWITCH_CYCLE& = 50650 
65 Global Const ND_INTERNAL_MAX_TIMEBASE& = 50660 

Global Const ND_PRESCALE_VALUE& = 50670 
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Global Const ND_MAX_PRESCALE& = 50690 
Global Const ND_INTERNAL_LINE_0& = 50710 
Global Const ND_INTERNAL_LINE_1 & = 50720 
Global Const ND_INTERNAL_LINE_2& = 50730 
Global Const ND_INTERNAL_LINE_3& = 50740 
Global Const ND_INTERNAL_LINE_4& = 50750 
Global Const ND_INTERNAL_LINE_5& = 50760 
Global Const ND_INTERNAL_LINE_6& = 50770 
Global Const ND_INTERNAL_LINE_7& = 50780 
Global Const ND_BMTERNAL_LINE_8& = 50790 
Global Const ND_INTERNAL_LINE_9& = 50800 
Global Const ND_INTERN AL_LINE_ 1 0& = 50810 
Global Const ND_INTERNAL_LINE_1 1& = 50820 
Global Const ND_INTERNAL_LINE_12& = 50830 
Global Const ND_INTERNAL_LINE_13& = 50840 
Global Const ND_INTERNAL_LINE_14& = 50850 
Global Const ND_INTERN AL_LINE_1 5 & = 50860 
Global Const ND_INTERNAL_LINE_16& = 50862 
Global Const ND_INTERN AL_LINE_ 1 7& = 50864 
Global Const ND_INTERNAL_LINE_18& = 50866 
Global Const NDJNTERN AL_LINE_1 9& = 50868 
Global Const ND_INTERNAL_LINE_20& = 50870 
Global Const ND_INTERN AL_LINE_2 1 & = 50872 
Global Const ND_INTERNAL_LINE_22& = 50874 
Global Const ND_INTERNAL_LINE_23& = 50876 



Global Const ND_START_TRIGGER& = 51150 

Global Const ND_START_TRIGGER_POLARITY& = 51 151 



Global Const ND_COUNTING_SYNCHRONOUS& = 51200 

Global Const ND_SYNCHRONOUS& = 51210 

Global Const ND_ASYNCHRONOUS& = 51220 

Global Const ND_CONFIGURABLE_FILTER& = 51230 

Global Const ND_ENCODER_TYPE& = 51240 

Global Const ND_Z_INDEX_ACTIVE& = 51250 

Global Const ND_Z_INDEX_VALUE& = 51260 

Global Const ND_SNAPSHOT& = 51270 

Global Const ND_POSITION_MSR& = 51280 

Global Const ND_BUFFERED_POSITION_MSR& = 51290 

Global Const ND_SAVED_COUNT& = 51300 

Global Const ND_READ_MARK_H_SNAPSHOT& = 51310 

Global Const ND_READ_MARK_L_SNAPSHOT& = 51320 

Global Const ND_WRITE_MARK_H_SNAPSHOT& = 51330 

Global Const ND_WRITE_MARK_L_SNAPSHOT& = 51340 

Global Const ND_BACKLOG_H_SNAPSHOT& = 51350 

Global Const ND_BACKLOG_L_SNAPSHOT& = 51360 

Global Const ND_ARMED_SNAPSHOT& = 51370 

Global Const ND_EDGE_GATED_FSK& = 51371 

Global Const ND_SIMPLE_GATED_EVENT_CNT& = 51372 

Global Const ND_VIDEO_TYPE& = 51380 

Global Const ND_PAL_B& = 51390 

Global Const ND_PAL_G& = 51400 

Global Const ND_PAL_H& = 51410 

Global Const ND_PAL_I& = 51420 

Global Const ND_PAL_D& = 51430 

Global Const ND_PAL_N& = 51440 

Global Const ND_PAL_M& = 51450 

Global Const ND_NTSC_M& = 51460 

Global Const ND_COUNTER_TYPE& = 51470 
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Global Const ND_NI_TIO& = 51480 

Global Const ND_AM9513& = 51490 

Global Const ND_STC& = 51500 

Global Const ND_8253& = 51510 

Global Const ND_A_HIGH_B_HIGH& = 51520 

Global Const ND_A_HIGH_B_LOW& = 51530 

Global Const ND_A_LOW_B_HIGH& = 51540 

Global Const ND_A_LOW_B_LOW& = 51550 

Global Const ND_Z_INDEX_RELOAD_PHASE& = 51560 

Global Const ND_UPDOWN_LINE& = 51570 

Global Const NDJ3EFAULT_PFI_LINE& = 51580 

Global Const NDJBUFFER.SIZE& = 51590 

Global Const ND_ELEMENT_SIZE& = 51600 

Global Const ND_NUMBER_GP_COUNTERS& = 51610 

Global Const ND_BUFFERED_TIME_STAMPING& = 51620 

Global Const ND_TIME_0_DATA_32& = 51630 

Global Const ND_TIME_8_DATA_24& = 51640 

Global Const ND_TIME_16_DATA_16& = 51650 

Global Const ND_TIME_24_DATA_8& = 51660 

Global Const ND_TIME_32_DATA_32& = 51670 

Global Const ND_TIME_48_DATA_16& = 51680 

Global Const ND_ABS OLUTE& = 51690 

Global Const ND_RELATIVE& = 51700 

Global Const ND_TIME_DATA_SIZE& = 51710 

Global Const ND_TIME_FORMAT& = 51720 

Global Const ND_HALT_ON_OVERFLOW& = 51730 

Global Const ND_OVERLAY_RTSI_ON_PFI_LINES& = 51740 

Global Const ND_STOP_TRIGGER& = 51750 

Global Const ND_TS_INPUT_MODE& = 51760 

Global Const ND_BOTH_EDGES& = 51770 

Global Const ND_CLOCK_0& = 51780 

Global Const ND_CLOCK_l& = 51790 

Global Const ND_CLOCK_2& = 51800 

Global Const ND_CLOCK_3& = 51810 

Global Const ND_SYNCHRONIZATION_LINE& = 51820 

Global Const ND_TRANSFER_METHOD& = 51830 

Global Const ND.SECONDS& = 51840 

Global Const ND_PRECISION& = 51850 

Global Const ND_NANO_SECONDS& = 51860 

Global Const ND_SYNCHRONIZATION_METHOD& = 51870 

Global Const ND_PULSE_PER_SECOND& = 51880 

Global Const ND_IRIG_B& = 51890 

Global Const ND_SIMPLE_TIME_MSR& = 51900 

Global Const ND_SINGLE_TIME_MSR& = 51910 

Global Const ND_BUFFERED_TIME_MSR& = 51920 

Global Const ND_DMA& = 51930 

NIDAQERR.INC Module 



** nidaqerr.inc *' 

* header file for platform-independent ni-daq errors/warnings 

•* NOTE: *' 
55 ^ You should use symbols defined here in your programs; do m 

* use the numerical values. *' 

** Warnings are returned as positive numbers. For example 
overWriteError may be returned as a warning and its value 
60 * would be -(overWriteError). *' 



* THIS FILE IS AUTOMATICALLY GENERATED FROM A DATABASE: DO NOT EDIT * 



Global Const noError = 0 
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60 



Global Const syntaxError = -10001 
ordering ... 

Global Const semanticsError = -10002 
string is ... 

Global Const invalidValueError = -10003 
Global Const valueConflictError = -10004 
one, and ... 

Global Const badDeviceError = -10005 
Global Const badLineError = -10006 
Global Const badChanError = -10007 
or device ... 

Global Const badGroupError = -10008 
Global Const badCounterError = -10009 
Global Const badCountError = -10010 
the... 

Global Const badlntervalError = -1001 1 
channels and ... 

Global Const badRangeError = -10012 
invalid ... 

Global Const badErrorCodeError = -10013 
Global Const groupTooLargeError = -10014 
Global Const badTimeLimitError = -10015 
Global Const badReadCountError = -10016 
Global Const badReadModeError = -10017 
Global Const badReadOffsetError = -10018 
Global Const badClkFrequencyError = -10019 
Global Const badTimebaseError = -10020 
Global Const badLimitsError = -10021 
Global Const badWriteCountError = -10022 
trying to write ... 

Global Const badWriteModeError = -10023 
Global Const badWriteOffsetError = -10024 
mark outside ... 

Global Const limitsOutOfRangeError = -10025 
configuration. ... 

Global Const badBufferSpecificationError = -10026 
allowed. For ... 

Global Const badDAQEventError = -10027 
than 0 and less ... 

Global Const badFilterCutoffError = -10028 
Global Const obsoleteFunctionError = -10029 
version of ... 

Global Const badBaudRateError = -10030 
port is not ... 

Global Const badChassisIDError = -1003 1 
port is not ... 

Global Const badModuleSlotError = -10032 
corresponds to an ... 

Global Const invalidWinHandleError = -10033 
Global Const noSuchMessageError = -10034 
Global Const irrelevantAttributeError = -10035 
Global Const badYearError = -10036 
Global Const badMonthError = -10037 
Global Const badDayError = -10038 
Global Const stringTooLongError = -10039 
DAQScope 5102 devices ... 
Global Const badGroupSizeError = -10040 
Global Const badTasklDError = -10041 
connected ... 

Global Const inappropriateControlCodeError = - 1 0042 ' The specified control code is inappropriate for the 
current configuration ... 

Global Const badDi visorError = - 1 0043 ' The specified divisor is invalid. 

Global Const badPolarityError = -10044 ' The specified polarity is invalid. 

Global Const badlnputModeError = -10045 * The specified input mode is invalid. 

Global Const badExcitationError = -10046 ' The excitation value specified is not valid for this device. 



An error was detected in the input string; the arrangement or 
' An error was detected in the input string; the syntax of the 



' The value of a numeric parameter is invalid. 
' The value of a numeric parameter is inconsistent with another 

' The device is invalid. 
' The line is invalid. 

'A channel, port, or counter is out of range for the device type 

"The group is invalid. 
' The counter is invalid. 

' The count is too small or too large for the specified counter, or 

' The analog input scan rate is too fast for the number of 

' The analog input or analog output voltage or current range is 

"The driver returned an unrecognized or unlisted error code. 
' The group size is too large for the board. 
' The time limit is invalid. 
' The read count is invalid. 
' The read mode is invalid. 
' The offset is unreachable. 

' The frequency is invalid. 
' The timebase is invalid. 
' The limits are beyond the range of the board. 

' Your data array contains an incomplete update, or you are 

' The write mode is out of range or is disallowed. 
'Adding the write offset to the write mark places the write 

' The requested input limits exceed the board's capability or 

The requested number of buffers or the buffer size is not 

' For DAQEvents 0 and 1 general value A must be greater 

' The cutoff frequency specified is not valid for this device. 
' The function you are calling is no longer supported in this 

' The specified baud rate for communicating with the serial 

'The specified baud rate for communicating with the serial 

'The SCXI module slot that was specified is invalid or 

' The window handle passed to the function is invalid. 
' No configured message matches the one you tried to delete. 
' The specified attribute is not relevant. 
The specified year is invalid. 
' The specified month is invalid. 
The specified day is invalid. 
' The specified input string is 



olong. For instance, 



"The group size is invalid. 

The specified task ID is invalid. For instance, you may have 
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Global Const badConnectionTypeError = -10047 
Global Const badExcitationTypeError = -10048 
Global Const badChanListError = -10050 
corresponds ... 

Global Const badTrigSkipCountError = -10079 
Global Const badGainError = -10080 
Global Const badPretrigCountError = -10081 
Global Const badPosttrigCouniError = -10082 
Global Const badTrigModeError = -10083 
Global Const badTrigCountError = -10084 
Global Const badTrigRangeError = -10085 
Global Const badExtRefError = -10086 
Global Const badTrigTypeError = -10087 
Global Const badTrigLevelError = -10088 
Global Const badTotalCountError = -10089 
pretrigger scan ... 

Global Const badRPGError = -10090 
the combination ... 

Global Const badlterationsError = -10091 
parameter. ... 

Global Const lowScanlntervalError = -10092 
a scan and ... 

Global Const fifoModeError = -10093 
least one condition ... 

Global Const badCalDACconstError = -10094 
Global Const badCalStimulusError = -10095 
Global Const badCalibrationConstantError 
Global Const badCalOpError = -10097 
Global Const badCalConstAreaError = -10098 
instance, the ... 

Global Const badPortWidthError = -10100 
hardware port ... 
Global Const gpctrBadApplicationError = -10120 
Global Const gpctrBadCtrNumberError = -10121 
Global Const gpctrBadParamValueError = -10122 
Global Const gpctrBadParamlDError = -10123 
Global Const gpctrBadEntitylDError = -10124 
Global Const gpctrBadActionError = -10125 
Global Const gpctrSourceSelectError = -10126 
Global Const badCountDirError = -10127 
direction. 

Global Const badGateOptionError = -10128 
Global Const badGateModeError = -10129 
Global Const badGateSourceError = -10130 
Global Const badGateSignalError = -10131 
Global Const badSourceEdgeError = -10132 
Global Const badOutputTypeError = -10133 
Global Const badOutputPolarityError = -10134 
Global Const badPulseModeError = -10135 
Global Const badDutyCycleError = -10136 
Global Const badPulsePeriodError = -10137 
Global Const badPulseDelay Error = -10138 
Global Const badPulseWidthError = -10139 
Global Const badFOUTportError = -10140 
port is invalid. 

Global Const badAutoIncremenfModeError : 
Global Const badNotchFilterError = -10180 
Global Const badMeasModeError = -10181 
Global Const EEPROMreadError = -10200 
Global Const EEPROMwriteError = -10201 



' The excitation value specified is not valid for this device. 



' The excitation type specified is n 
' There is more than one channel nan 



t valid for this device. 
: in the channel list that 



' The trigger skip count is invalid. 
1 The gain or gain adjust is invalid. 

' The pretrigger sample count is invalid. 
' The posttrigger sample count is invalid. 
' The trigger mode is invalid. 
"The trigger count is invalid. 

' The trigger range or trigger hysteresis window is invalid. 
' The external reference is invalid. 
"The trigger type is invalid. 
' The trigger level is invalid. 

' The total count is inconsistent with the buffer size and 



' The individual range, polarity, and gain settings are valid but 

' You have attempted to use an invalid setting for the iteration: 

' Some devices require a time gap between the last sample ii 

FIFO mode waveform generation cannot be used because at 

' The calDAC constant passed to the function is invalid. 
' The calibration stimulus passed to the function is invalid. 
10096 ' The specified calibration constant is invalid. 
' The specified calibration operation is invalid. 

' The specified calibration constant area is invalid. For 

' The requested digital port width is not a multiple of the 



' Invalid application used. 
' Invalid counterNumber used. 
' Invalid paramValue used. 
' Invalid paramID used. 
' Invalid entitylD used. 
' Invalid action used. 
' Invalid source selected. 
' The specified counter does not support the specified count 

' The specified gating option is invalid. 
' The specified gate mode is invalid. 
'The specified gate source is invalid. 
' The specified gate signal is invalid. 
' The specified source edge is invalid. 
' The specified output type is invalid. 
"The specified output polarity is invalid. 
' The specified pulse mode is invalid. 
"The specified duty cycle is invalid. 
' The specified pulse period is invalid. 
' The specified pulse delay is invalid. 
' The specified pulse width is invalid. 
' The specified frequency output (FOUT or FREQ_OUT) 



Global Const EEPROMwriteProtectionError = -10202 
EEPROM because it... 

Global Const EEPROMinvalidLocationError = -10203 
Global Const EEPROMinvalidPasswordError = -10204 
incorrect. 

Global Const noDriverError = -10240 



10141 ' The specified autoincrement mode is invalid. 
' The specified notch filter is invalid. 
' The specified measurement mode is invalid. 
' Unable to read data from EEPROM. 
Unable to write data to EEPROM. 



' You cannot write into this location or area of your 



' The specified EEPROM location is invalid. 
' The password for accessing the EEPROM is 



The driver interface could not locate or open the driver.. 
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Global Const oldDriverError = -10241 
or ... 

Global Const functionNotFoundError = -10242 
Global Const configFileError = -10243 
the format ... 

Global Const devicelnitError = -10244 
attempting ... 

Global Const osInitError = -10245 
attempting to perform ... 
Global Const communicationsError = -10246 
attempting to perform ... 
Global Const cmosConfigError = -10247 
invalid, or the... 

Global Const dupAddressError = -10248 
consequently, ... 

Global Const intConfigError = -10249 
the ... 

Global Const dupIntError = -10250 
Global Const dmaConfigError = -10251 
the computer/DMA ... 
Global Const dupDMAError = -10252 
Global Const jumperlessBoardError= -10253 
configured using ... 

Global Const DAQCardConfError = -10254 
version of the card ... 

Global Const remoteChassisDriverlnitError = - 10255 ' There 
SCXI. 

Global Const comPortOpenError = -10256 
Global Const baseAddressError = -10257 
Global Const dmaChannell Error = -10258 
by the operating ... 

Global Const dmaChannel2Error = -10259 
by the operating ... 

Global Const dmaChanneBError = -10260 
by the operating ... 



' One of the driver files or the configuration utility is out of date, 

' The specified function is not located in the driver. 
' The driver could not locate or open the configuration file, or 

' The driver encountered a hardware-initialization error while 

The driver encountered an operating-system error while 

' The driver encountered an operating-system error while 

' The CMOS configuration-memory for the device is empty or 

' The base addresses for two or more devices are the same; 

' The interrupt configuration is incorrect given the capabilities of 

' The interrupt levels for two or more devices are the same. 
' The DMA configuration is incorrect given the capabilities of 

' The DMA channels for two or more devices are the same. 
' Unable to find one or more jumperless boards you have 

' Cannot configure the DAQCard because 1) the correct 

n error in initializing the driver for Remote 

' There was an error in opening the specified COM port. 
Bad base address specified in the configuration utility. 
' Bad DMA channel 1 specified in the configuration utility or 

' Bad DMA channel 2 specified in the configuration utility or 

' Bad DMA channel 3 specified in the configuration utility or 



Global Const userModeToKernelModeCallError = -10261 ' The user mode code failed when calling the kernel 
mode code. 



Global Const noConnectError = -10340 
signal and the ... 

Global Const badConnectError = -10341 
Global Const multConnectError = -10342 
line, or the ... 

Global Const SCXIConfigError = -10343 
the function ... 

Global Const chassisSynchedError = -10344 
Reset the chassis ... 

Global Const chassisMemAUocError = -10345 
Remote SCXI unit ... 
Global Const badPacketError = -10346 
Check your serial ... 

Global Const chassisCommunicationError = -10347 
chassis. Check your... 

Global Const waitingForReprogError = -10348 
waiting for reprogramming ... 
Global Const SCXIModuleTypeConflictError = -10349 ' The module ID read from the SCXI module conflicts 
with the configured ... 

Global Const CannotDetermineEntryModuleError = -10350 ' Neither an SCXI entry module (i.e.: the SCXI 
module cabled to the measurement ... 

Global Const DSPInitError = -10360 ' The DSP driver was unable to load the kernel for its operating 

system. 

Global Const badScanListError = -1 0370 
64T channels ... 

Global Const invalidSignalSrcError = -10380 ' The specified signal source is invalid for the selected signal 



' No RTSI or PFI signal/line is connected, or the specified 

' The RTSI or PFI signal/line cannot be connected as specified. 
"The specified RTSI signal is already being driven by a RTSI 

' The specified SCXI configuration parameters are invalid, or 

' The Remote SCXI unit is not synchronized with the host. 

' The required amount of memory cannot be allocated on the 

' The packet received by the Remote SCXI unit is invalid. 

' There was an error in sending a packet to the remote 

The Remote SCXI unit is in reprogramming mode and is 



' The scan list is invalid; for example, you are mixing AMUX- 



65 Global Const invalidSignalNameError = - 1 038 1 



' The specified signal name is invalid. 
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Global Const invalidSrcSpecError = -10382 
source or ... 

Global Const mvalidSignalDestError = -10383 
Global Const userOwnedRsrcError = -10400 
accessed or ... 

Global Const unknownDeviceError = -10401 
the driver ... 

Global Const deviceNotFoundError = -10402 
the driver ... 

Global Const deviceSupportError = -10403 
(the driver ... 

Global Const noLineAvailError = -10404 
Global Const noChanAvailError = -10405 
Global Const noGroupAvailError = -10406 
Global Const lineBusy Error = -10407 
Global Const chanBusyError = -10408 
Global Const groupBusy Error = -10409 
Global Const relatedLCGBusyError = -10410 
configures ... 

Global Const counterBusyError = -10411 
Global Const noGroupAssignError = -10412 
cannot be assigned ... 
Global Const groupAssignError = -10413 
is already ... 

Global Const reservedPinError = -10414 
configured only ... 

Global Const extern alMuxSupportError = -10415 
external multiplexer ... 
Global Const sysOwnedRsrcError = -10440 
accessed or ... 

Global Const memConfigError = -10441 
mode, or ... 

Global Const memDisabledError = -10442 
current addressing ... 

Global Const memAlignmentError = -10443 
data-transfer ... 

Global Const memFullError = -10444 

memory is available ... 

Global Const memLockError = -10445 

On PC AT machines, ... 

Global Const memPageError = -10446 

may require ... 

Global Const memPageLockError = -10447 
Global Const stackMemError = -10448 
Global Const cacheMemError = -10449 
the current ... 

Global Const physicalMemError = -10450 
memory is located ... 
Global Const virtualMemError = -10451 
virtual ... 

Global Const noIntAvailError = -10452 
Global Const intlnUseError = -10453 
Global Const noDMACError = -10454 
Global Const noDMAAvailError = -10455 
Global Const DMAInUseError = -10456 
device. 

Global Const badDMAGroupError = -10457 

because it is too small, ... 

Global Const diskFullError = -1 0458 

Global Const DLLInterfaceError = -10459 

error. 

Global Const interfacelnteractionError = -10460 
compatibility library ... 

Global Const resourceReservedError = -10461 
been reserved ... 



"The specified source specification is invalid for the signal 

"The specified signal destination is invalid. 

' The specified resource is owned by the user and cannot be 

"The specified device is not a National Instruments product, 

' The specified device is not a National Instruments product, 

"The specified device does not support the requested action 

' No line is available. 
' No channel is available. 
' No group is available. 
' The specified line is in use. 
' The specified channel is in use. 
' The specified group is in use. 

* A related line, channel, or group is in use; if the driver 

' The specified counter is in use. 
' No group is assigned, or the specified line or channel 

' A group is already assigned, or the specified line or channel 

' The selected signal requires a pin that is reserved and 

' This function does not support your DAQ device when an 

' The specified resource is owned by the driver and cannot be 

' No memory is configured to support the current data-transfer 

' The specified memory is disabled or is unavailable given the 

' The transfer buffer is not aligned properly for the current 

' No more system memory is available on the heap, or no more 

'The transfer buffer cannot be locked into physical memory. 

' The transfer buffer contains a page break; system resources 

' The operating environment is unable to grant a page lock. 
' The operating environment is unable to grant a page lock. 
'A cache-related error occurred, or caching is not supported in 

'A hardware error occurred in physical memory, or no 

' The driver is unable to make the transfer buffer contiguous in 

' No interrupt level is available for use. 

' The specified interrupt level is already in use by another device. 
'No DMA controller is available in the system. 
' No DMA channel is available for use. 
' The specified DMA channel is already in use by another 

' DMA cannot be configured for the specified group 

The storage disk you specified is full. 
' The NI-DAQ DLL could not be called due to an interface 

' You have mixed Vis from the DAQ library and the _DAQ 

' The specified resource is unavailable because it has already 
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' The specified resource is 



ailable because it has 



55 



Global Const resourceNotReservedError = -10462 
already been reserved ... 

Global Const mdResourceAlreadyReservedError = -10463 ' Another entity has already reserved the requested 
resource. 

Global Const mdResourceReservedError - -10464 
resource. 

Global Const mdResourceNotReservedError = - 1 0465 ' Attempting to lift a reservation off a 
previously had no... 

Global Const mdResourceAccessKeyError = -10466 ' The requested operation cannot be performed because 
the key supplied is ... 

Global Const mdResourceNotRegisteredError = -10467 ' The resource requested is not registered with the 
minidriver. 

Global Const muxMemFullError = -10480 
Global Const bufferNotlnterleavedError = -10481 
the channels ... 

Global Const SCXIModuleNotSupportedError = - 10540 ' You must provide a single buffer of interleaved data, 
and the channels ... 

Global Const TRIGlResourceConflict = -10541 ' CTRB 1 will drive COUTB1, however CTRB1 will also 

drive TRIG1. This may ... 

Global Const matrixTerminalBlockError = -10542 ' This function requires that no Matrix terminal block is 
configured with ... 

Global Const noMatrixTerminalBlockError = - 1 0543 ' This function requires that some matrix terminal block 
is configured with ... 

Global Const invalidMatrixTerminalBlockError = -10544 ' The type of matrix terminal block configured will not 
allow proper operation 

'The DSP handle input is not valid . 
' Either DAQ or WFM can use a PC memory buffer, but 



' Another entity has already reserved the requested 



'The 
'You 



requested is not registered with the minidriver. 
provide a single buffer of interleaved data, and 



Global Const invalidDSPHandleError = -10560 
Global Const DSPDataPathBusyError = -10561 
not both at the same ... 
Global Const noSetupError = -10600 
resources. Or, ... 

Global Const multSetupError = -10601 
resources. Or, ... 

Global Const noWriteError = -10602 
Global Const groupWriteError = -10603 
channel or ... 

Global Const activeWriteError = -10604 
originally ... 

Global Const endWriteError = -10605 
block ... 

Global Const notArmedError = -10606 
Global Const armedError = - 1 0607 
Global Const noTransferlnProgError = -10608 
Global Const transferlnProgError = -10609 
the operation ... 

Global Const transferPauseError = -10610 
output data... 

Global Const badDirOnSomeLinesError = -1061 1 
configured for the ... 
Global Const badLineDirError = -10612 
direction. 

Global Const badChanDirError = -10613 
direction, ... 

Global Const badGroupDirError = -10614 
direction. 

Global Const masterClkError = -10615 
Global Const slaveClkError = -10616 
Global Const noClkSrcError = -10617 
Global Const badClkSrcError = -10618 
resource. 

Global Const multClkSrcError = -10619 
resource. 

Global Const noTrigError = -10620 
Global Const badTrigError = -10621 
Global Const preTrigError = -10622 



Global Const postTrigError = -10623 



' No setup operation has been performed for the specified 

' No setup operation has been performed for the specified 

'No output data has been written into the transfer buffer. 
' The output data associated with a group must be for a single 

' Once data generation has started, only the transfer buffers 

' No data was written to the transfer buffer because the final data 

' The specified resource is not armed. 
The specified resource is already armed. 

'No transfer is in progress for the specified resource. 
' A transfer is already in progress for the specified resource, or 

' A single output channel in a group may not be paused if the 

' Some of the lines in the specified channel are not 

' The specified line does not support the specified transfer 

"The specified channel does not support the specified transfer 

' The specified group does not support the specified transfer 

' The clock configuration for the clock master is invalid. 
' The clock configuration for the clock slave is invalid. 
'No source signal has been assigned to the clock resource. 
' The specified source signal cannot be assigned to the clock 

' A source signal has already been assigned to the clock 

' No trigger signal has been assigned to the trigger resource. 
' No trigger signal has been assigned to the trigger resource. 
' The pretrigger mode is not supported or is not available in the 

'No posttrigger source has been assigned. 
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Global Const delay TrigError = -10624 
the current... 
Global Const masterTrigError = -10625 
Global Const slaveTrigError = -10626 
Global Const noTrigDrvError = -10627 
Global Const multTrigDrvError = -10628 
Global Const invalidOpModeError = -10629 
have not been... 

Global Const invalidReadError = -10630 
context of the ... 

Global Const noInfiniteModeError = -10631 
current operating ... 

Global Const somelnputsIgnoredError = -10632 
in the current ... 

Global Const invalidRegenModeError = -10633 
allowed for this . 



' The delayed trigger mode is not supported or is not available in 

' The trigger configuration for the trigger master is invalid. 
' The trigger configuration for the trigger slave is invalid. 
' No signal has been assigned to the trigger resource. 
' A signal has already been assigned to the trigger resource. 
' The specified operating mode is invalid, or the resources 

'The parameters specified to read data were invalid in the 

* Continuous input or output transfers are not allowed in the 

' Certain inputs were ignored because they are not relevant 

'The specified analog output regeneration mode is not 



Global Const noContTransferlnProgressError = -10634 ' No continuous (double buffered) transfer is in progress 
for the specified ... 



Global Const invalidSCXIOpModeError = -10635 
configuration call is invalid, ... 
Global Const noContWithSynchError = -10636 
with a synchronous ... 

Global Const bufferAlreadyConfigError = -10637 
already been configured. ... 

Global Const badClkDestError = -10638 ' The clock cannot be assigned to the specified destination. 

Global Const rangeBadForMeasModeError = -10670 ' The input range is invalid for the configured 
measurement mode. 

Global Const autozeroModeConflictError = -10671 ' Autozero cannot be enabled for the configured 
measurement mode. 

Global Const badChanGainError = -10680 ' All channels of this board must have the same gain. 

Global Const badChanRangeError = -10681 ' All channels of this board must have the same range. 

Global Const badChanPolarityError = -10682 ' All channels of this board must be the same polarity. 

' All channels of this board must have the same coupling. 
' All channels of this board must have the same input 



' Either the SCXI operating mode specified in a 
You cannot start a continuous (double-buffered) operation 
Attempted to configure a buffer after the buffer had 



Global Const badChanCouplingError = -10683 
Global Const badChanlnputModeError = -10684 
mode. 

Global Const clkExceedsBrdsMaxConvRateErroi 
maximum rate. 

Global Const scanListlnvalidError = -10686 
Global Const bufferlnvalidError = -10687 
or an acquisition ... 

Global Const noTrigEnabledError = -10688 
triggered ... 

Global Const digitalTrigBError = -10689 
pretrigger ... 

Global Const digitalTrigAandBError = -10690 
enabled at the ... 

Global Const extConvRestrictionError = -10691 
external scan ... 

Global Const chanClockDisabledError = -10692 
an external scan ... 

Global Const extScanClockError = -10693 
scan of a single ... 

Global Const unsafeSamplingFreqError = -10694 
minimum for the hardware, ... 
Global Const DMAnotAllowedError = -10695 
interrupts. DMA ... 

Global Const multiRateModeError = -10696 
SCXI, orpretriggered ... 
Global Const rateNotSupportedError = -10697 
actual hardware ... 

Global Const timebaseConflictError = -10698 
timebases for ... 

Global Const polarityConflictError = -10699 
source polarities ... 

Global Const signalConflictError = -10700 
signal sources ... 



= - 1 0685 ' The clock rate exceeds the board's recommended 

' A configuration change has invalidated the scan list. 
' A configuration change has invalidated the acquisition buffer, 

'The number of total scans and pretrigger scans implies that a 

' Digital trigger B is illegal for the number of total scans and 

' This board does not allow digital triggers A and B to be 

'This board does not allow an external sample clock with an 

' This board does not allow an external sample clock with 

' You cannot use an external scan clock when doing a single 

' The scan rate is above the maximum or below the 

' You have set up an operation that requires the use of 

' Multi-rate scanning cannot be used with the AMUX-64, 

' Unable to convert your timebase/interval pair to match the 

' You cannot use this combination of scan and sample clock 

' You cannot use this combination of scan and sample clock 

' You cannot use this combination of scan and convert clock 
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Global Const noLaterUpdateError = -10701 
been set ... 

Global Const prePostTriggerError = -10702 
simultaneously on the ... 
Global Const noHandshakeModeError = -10710 
handshaking. 

Global Const noEventCtrError = -10720 
operation. 

Global Const SCXITrackHoldError = -10740 
hold trigger ... 

Global Const sc2040InputModeError = -10780 
analog input channels ... 

Global Const outputTypeMustBeVoltageError = 
all analog input channels ... 
Global Const sc2040HoldModeError = -10782 
2040 configured ... 

Global Const calConstPolarityConflictError = -10783 ' Calibration constants in the load area have a different 
polarity from ... 

' The operation could not complete within the time limit. 
' An error occurred during the calibration process. Possible 



' The call had no effect because the specified channel had not 
' Pretriggering and posttriggering cannot be used 

' The specified port has not been configured for 
' The specified counter is not configured for event-counting 
' A signal has already been assigned to the SCXI track-and- 
' When you have an SC2040 attached to your device, all 
■10781 'When you have an SC2040 attached to your device, 
' The specified operation cannot be performed with the SC- 
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Global Const timeOutError = -10800 
Global Const calibrationError = -10801 
reasons for ... 
Global Const dataNotAvailError = -10802 
Global Const transferStoppedError = -10803 
regeneration ... 

Global Const earlyStopError = -10804 
buffer. 

Global Const overRunError = -10805 
attempt to ... 

Global Const noTrigFoundError = -10806 
Global Const earlyTrigError = -10807 
acquired. 

Global Const LPTcommunicationError = -10 
acquired. 

Global Const gateSignalError = -10809 
the phase ... 

Global Const internalDriverError = -10810 

performing this given ... 

Global Const softwareError = -10840 

between accesses ... 

Global Const firmwareError = -10841 

firmware ... 

Global Const hardwareError = -10842 
the response ... 

Global Const underFlowError = -10843 
driver could not ... 

Global Const underWriteError = -10844 
generation ... 

Global Const overFlowError = -10845 
could not ... 

Global Const overWriteError = -10846 
background acquisition ... 
Global Const dmaChainingError = -10847 
DMA chaining ... 

Global Const noDMACountAvailError = -10{ 
transfer-count register ... 
Global Const OpenFileError = -10849 
Global Const closeFileError = -10850 
Global Const fileSeekError = -10851 
Global Const readFileError = -10852 
Global Const writeFileError = -10853 
Global Const miscFileError = -10854 
Global Const osUnsupportedError = -10855 
particular version ... 
Global Const osError = -10856 
performing ... 



' The requested amount of data has not yet been acquired. 
' The on-going transfer has been stopped. This is to prevent 

' The transfer stopped prior to reaching the end of the transfer 

' The clock rate is faster than the hardware can support. An 

' No trigger value was found in the input transfer buffer. 
' The trigger occurred before sufficient pretrigger data was 

08 ' The trigger occurred before sufficient pretrigger data was 

' Attempted to start a pulse width measurement with the pulse in 

' An unexpected error occurred inside the driver when 

' The contents or the location of the driver file was changed 

' The firmware does not support the specified operation, or the 

' The hardware is not responding to the specified operation, or 

' Because of system and/or bus-bandwidth limitations, the 

' Your application was unable to deliver data to the background 

' Because of system and/or bus-bandwidth limitations, the driver 

' Your application was unable to retrieve data from the 

' New buffer information was not available at the time of the 

18 ' The driver could not obtain a valid reading from the 

' The configuration file or DSP kernel file could not be opened. 
' Unable to close a file. 
'Unable to seek within a file. 
'Unable to read from a file. 
' Unable to write to a file. 
'An error occurred accessing a file. 

' NI-DAQ does not support the current operation on this 

'An unexpected error occurred from the operating system while 
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Global Const internalKemelError = -10857 
while performing ... 

Global Const hardwareConfigChangedError = - 10858 'The system has reconfigured the device and has 
invalidated the existing ... 
Global Const updateRateChangeError = - 
because 1) when ... 

Global Const partialTransferCompleteError = -10881 ' You cannot do another transfer after a successful partial 
transfer. 

' The data collected on the Remote SCXI unit was 



'An unexpected error occurred inside the kernel of the device 



' A change to the update rate is not possible at this time 



Global Const daqPoIlDataLossError = -10882 
overwritten before it could ... 
Global Const wfmPollDataLossError = -10883 
of the Remote ... 

Global Const pretrigReorderError = -10884 
completed. 

Global Const overLoadError = -10885 
Global Const gpctrDataLossError = -10920 
GPCTR operations... 

Global Const chassisResponseTimeoutError = -10940 ' No response was received from the Remote SCXI unit 
within the specified ... 

Global Const reprograrnrningFailedError = -10941 
Please try again. 

Global Const invalidResetSignatureError = -10942 
Please try again. 

Global Const chassisLockupError = -10943 ' The interrupt service routine on the remote SCXI unit 

taking longer ... 



' New data could not be transferred to the waveform buffer 
Could not rearrange data after a pretrigger acquisition 



' The input signal exceeded the input range of the ADC. 
' One or more data points may have been lost during buffered 



' Reprogramming the Remote SCXI unit was unsuccessful. 
Reprogramming the Remote SCXI unit was unsuccessful. 



* Warnings 

"* dupIOaddrRange 

dupIntLevels 
^ dupDMALevels 
** readOutputPort 

* calibrationErr 
** noPreTrigUnwrap 

* relatedPortBusy 
readOutputLine 

* outOnSomelnLines 

* inOnSomeOufLines 
^ simulOpAcrossChips 

overWriteBeforeCopy 

* pageBreakinWFbuf 
^ wrongNumConfigBytes 
^ DMAReprogramming 

* SCXImoduleTypeConflict 

* notEnoughExtMem 
inputModeConflict 

* SCXIConfigWarning 
"* messagelntervalTooLong 
"* logicalDevice Warning 
"* calConstPolarityConflict 

* irqConflict 

* dmaConflict 



* jumperlessBoardWarning 

* gpctrDataLoss Warning 



-(dupAddressError) 
-(dupIntError) 

-(dupDMAError) 
-(badChanDirError) 
(calibrationError) 

-(memFullError) 
-(relatedLCGBusyError) 
-(badDirOnSomeLinesError) 
-(badDirOnSomeLinesError) 
-(badDirOnSomeLinesError) 
-(invalidOpModeError) 
-(overWriteError) 
-(memPageError) 
-(noSetupError) 
-(memPageError) 
-(SCXIModuleTypeConflictError) 
-(memFullError) 
(invalidOpModeError) 
-(SCXIConfigError) 
-(badDAQEventError) 
-(badDeviceError) 
-(calConsfPolarityConflictError) 
(dupIntError) 
(dupDMAError) 



-(jumperlessBoardError) 
-(gpctrDataLossError) 
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"* notOurBrdErr 

* badBrdNumErr 

* badGainErr 
** badChanErr 



unknownDeviceError 
badDeviceError 
badGainError 
badChanError 
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* noSupportErr 

* badPortErr 

* badOutPortErr 

** noLatchModeErr 
^ noGroupAssign 

* badlnputValErr 

* timeOutErr 

* outOfRangeErr 

* daqlnProgErr 

* counterlnUseErr 

* noDAQErr 
** overFlowErr 

* overRunErr 
** badCntErr 

* brdTypeErr 

* noCountOpErr 
"* ctrReservedErr 

* portAssignToGrp 

* noPortAssignErr 

* badGrpDirErr 

** noGrpBlocklnProg 

* grpBIocklnProg 

"* setLatchWGrpCall 

* laterlntUpdateNotSet 

* wflnProgErr 

* noWfLoadErr 

* no WflnProgErr 

* badPreTrigCntErr 

* buffNotFullErr 

* prePostTrigErr 
** extConvErr 

* badSigDirErr 
"* noDbDaqErr 
** overWriteErr 
** memErr 

* noConfigFile 

* badGrpSize 

* intLevellnUse 

* DMAChanlnUse 
multSourcelnputErr 

** lowScanlntervalErr 
** noConnectionErr 

* noPGInProg 

* PGInProg 
grpRateErr 

"* extGateErr 
^ openFileErr 
"* writeFileErr 
^ noDbWvfmErr 

* oldDataErr 

^ dataNotAvailErr 



deviceSupportError 
badChanError 
badChanDirError 
noHandshakeModeError 
noGroupAssignError 
invalidValueError 
timeOutError 
badRangeError 
transferlnProgError 
counterBusyError 
noTransferlnProgError 
overFlowError 
overRunError 
badCountError 
deviceSupportError 
noEventCtrError 
sys OwnedRsrcError 
groupAssignError 
noGroupAssignError 
badGroupDirError 

noTransferlnProgError 
transferlnProgError 
invalidValueError 
noLaterUpdateError 
transferlnProgError 
noWriteError 
noTransferlnProgError 
badPretrigCountError 
earlyTrigError 
prePostTriggerError 
extConvRestrictionError 
badLineDirError 
noContTransferlnProgError 
overWriteError 
memFullError 
configFileError 
badGroupError 
intlnUseError 
DMAInUseError 
multConnectError 
lowScanlntervalError 
noConnectError 
noTransferlnProgError 
transferlnProgError 
counterBusyError 
invalidOpModeError 
openFileError 
writeFileError 

noTransferlnProgError 
transferStoppedError 
dataNotAvailError 

* DMATransferCntNotAvail noDMACountAvailError 

* noLabScanErr noTransferlnProgError 

* dbOpErr noContWithSynchError 

* DMADisabledErr noDMAAvailError 

* invalidConfigErr cmosConfigError 
^ brdlsArmedErr armedError 

** clockSourceErr multClkSrcError 

* noSetupErr noSetupError 

** extConvDrvErr multClkSrcError 
"* triggerSourceErr badTrigError 

* noArmErr notArmedError 

* intDisabledErr nofntAvailError 

* keyNotFoundErr configFileError 
"* noTrigEnabledErr preTrigError 

* digPortReserved sysOwnedRsrcError 
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* RTSIlinelnUseErr 

* dacUpdateRTSIinUseErr 

* noRTSIlineAvailErr 

* preTrigScansErr 

* postTrigScansErr 
** scanRateErr 
** invalidGetErr 
** callnputOutOfRange 
"* EEPROMaddrErr 
"* EEPROMresponseErr 

* EEPROMreadErr 

* EEPROMwriteErr 

* calResponseErr 

* calConvergeErr 
•* calDACerr 

externalCalRefErr 
"* internalCalRefErr 
"* badOutLineErr 



sysOwnedRsrcError 

sysOwnedRsrcError 
noLineAvailError 
badPretrigCoimtError 
badPosttrigCountError 
badlntervalError 
invalidReadError 
badExtRefError 
EEPROMreadError 

EEPROMreadError 
EEPROMreadError 
EEPROMwriteError 
calibrationError 
calibrationError 
calibrationError 
badExtRefError 
hardwareError 
badLineDirError 



* relatedPortAssignToGrpBusy relatedLCGBusyError 

* dacUpdateErr underFlowError 

* muxMemFullErr muxMemFullError 

* interlvdDataAlignErr memAlignmentError 

* cannotAlignBufErr memAlignmentError 
cannotLockBufErr memLockError 

* cannotPageLockErr memPageLockError 
invalidChassisIDErr badChassisIDError 

** invalidModuleSlotErr badModuleSlotError 

* configFileErr conflgFileError 

* outdatedVDMADErr oldDriverError 
** ctrRTSINotAvailErr lineBusyError 

* dacUpdateRTSINotAvailErr lineBusyError 

* SCXIConfigErr SCXIConfigError 



* noDbDigErr 

* DbDigPartialComplete 

* SCXITrackHoldErr 

* wvfmGrpAssignErr 

* chanNotAssignedGrpEi 
** grpLoadErr 
** loadAfterStartErr 

* noUpdateRateErr 
"* chanPauseErr 

* DSPInitFailure 

* DSPDataPathlnUse 

* DSPDAQErr 

* DSPreserved3 

* DSPreserved4 
"* DSPreservedS 

SCXICommErr 
invalidOpModeErr 

* moduleNotSupported 
** DAQboardNotSupported 

* noNIDAQLibErr 
"* noNIDAQFuncErr 

* incompatibleVISRDErr 
** portllnLatchedModeErr 
"* invalidMemRegionErr 

* fifoModeErr 

* cannotFreeMemErr 

* memNotLockedErr 

* invalidWinHandleErr 

* trigEventNotAvailErr 

* memTypeNotSupportedErr 

* badChanStrErr 

* parseErr 



* noSuchMessageErr 

* badChanTypeErr 



noTransferlnProgError 
transferStoppedError 
SCXITrackHoldError 
groupAssignError 
noGroupAssignError 
groupWriteError 
activeWriteError 
noClkSrcError 
trans ferPauseError 
DSPInitError 

DSPDataPathBusyError 
internalKernelError 
badErrorCodeError 
badErrorCodeError 
badErrorCodeError 
communicationsError 
invalidSCXIOpModeError 
SCXIModuleNotSupportedError 
deviceSupportError 
noDriverError 
functionNotFoundError 
oldDriverError 
relatedLCGBusyError 
memLockError 
fifoModeError 

memConfigError 
memConfigError 
invalidWinHandleError 
DMANotAUowedError 
memConfigError 
syntaxError 
syntaxError 

noSuchMessageError 
badChanError 
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* badTrigValErr 
"* notOurDSPHandleErr 

* NIDAQInternalErr 

* preTrigReorderErr 

* badCtrErr 

* invalidCtrErr 

* timedMsglnUseErr 



badDAQEventError 

invalidDSPHandleError 
intemalDriverError 
pretrigReorderError 
badCounterError 
badCounterError 
counterBusyError 
invDAQModeTimedMsgErr DMANotAllowedError 
IptCommunicationErr LPTcoramunicationError 
multiRateModeError 
multiRateModeError 
intemalDriverError 
badlntervalError 
badlntervalError 



* multiRateAMUXErr 

* multiRatePreTrigErr 

* functionNotLinkedErr 

* scanlntervalTooLongErr 

* sarnplelntervalTooLongErr 



* updatelntervalTooLongErr badlntervalError 
•* gpctrBadApplicationErr gpctrBadApplicationError 

* gpctrBadCounterNumberErr gpctrBadCounterNumberError 
■* gpctrBadParamValueErr gpctrBadParamValueError 

gpcrrBadParamldError 
gpctrBadEntityldError 
gpctxBadActionError 

gateSignalError 
noSetupError 
counterBusyError 
noSetupError 
noSetupError 



** gpctrBadParamldErr 

* gpctrBadEntityldErr 

* gpctrBadActionErr 

'* gpctrBadGateSignalErr 

* gpctrNotArmedErr 

* gpctrNotResetErr 

* gpctrNotProgrammedErr 

* gpctrApplicationNotSetErr 



* gpctrBufferNotConfiguredErr bufferlnvalidError 

* gpctrCantChangeParameterErr counterBusyError 

* lptProtocoINotSupported LPTcommunicationError 
rateNotSupportedErr rateNotSupportedError 

timebaseConflictError 
polarityConflictError 
signalConflictError 
baseAddressError 
badErrorCodeError 



* timebaseConflictErr 

* polarityConflictErr 
signalConflictErr 

** baseAddressErr 
** interruptLevellErr 
"* interruptLevel2Err 

* dmaChannellErr 

* dmaChannel2Err 

* openSCManagerErr 

* openNIDAQServiceErr 
; startNIDAQServiceErr 



badErrorCodeError 
dmaChannel 1 Error 
dmaChannel2Error 
b adErrorCodeError 

badErrorCodeError 
badErrorCodeError 

* criticalResourceConflictErr badErrorCodeError 

* jumperlessBoardErr jumperlessBoardError 

* reservedPinErr reservedPinError 

* bufferNotlnterleavedErr bufferNotlnterleavedError 

* gpctrlnUseErr counterBusyError 

^ gpctrDataLossErr gpctrDataLossError 

* updateRateChangeErr updateRateChangeError 

* gpctrBufferConfiguredErr bufferAlreadyConfigError 
"* gpctrBufOprnNotlnProgErr noTransferlnProgError 

* badFilterFreqErr badFilterCutoffError 

* sc2040HoldModeErr sc2040HoldModeError 
sc2040InputModeError 
noSetupError 
DAQCardConfigError 

* partialTransferCompIeteErr partialTransferCompleteError 

* DMABufferAlignmentErr memAlignmentError 

* outputTypeMustBeVoltageErr outputTypeMustBeVoltageError 
"* osUnsupportedErr osUnsupportedError 

* osErr osError 



* sc2040InputModeErr 

* noSC2040ConfigErr 

* DAQCardConfigErr 



NIDEX32 MODULE 
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* TITLE: NIDEx32.bas 

** Header for supporting code module for NI-DAQ Examples 

* (32-bit Visual Basic version) 

5 "* DESCR: This header file is to be used with any NI-DAQ example 
** program. 

'NOTE: must also use nidaq32.bas 
10 and nidaqcns.bas 



"* Constants 

15 

** for IType' 

Global Const WFM_DATA_U8 = 0 
Global Const WFM_DATA_I16 = 2 
Global Const WFM_DATA_F64 = 4 
20 Global Const WFM_DATA_U32 = 7 

** internal constants - change if needed- 
Global Const WFM_PERIODS = 10 
Global Const WFM_MIN_PTS_IN_PERIOD = 2 
25 Global Const WFM_U8_MODULO = 256 
Global Const WFM_I16_AMPL = 2047 
Global Const WFM_F64_AMPL = 4.99 



* error return codes for NIDAQPlotWaveform and NIDAQMakeBuffer 
** these error codes are consistent with CVI error codes 
Global Const NIDAQEX_INVALID_BUFFER = -12 
Global Const NIDAQEX_INVALID_NUMPTS = -14 
Global Const NIDAQEX_INVALID_TYPE = -53 



Function prototypes 



Declare Function NIDAQPlotWaveform Lib "nidex32.dlT (pvBuffer As Any, By Val lNumPts&, ByVal lType&) 
As Integer 

Declare Function NIDAQMakeBuffer Lib "nidex32.dll" (pvBuffer As Any, ByVal lNumPts&, ByVal lType&) As 
Integer 

Declare Function NIDAQErrorHandler Lib "nidex32.dll" (ByVal iStatus%, ByVal strFuncName$, ByVal 
iIgnoreWarning%) As Integer 

Declare Function NIDAQDelay Lib "nidex32.dll" (ByVal dSec#) As Integer 
Declare Function NIDAQYield Lib "nidex32.dll" (ByVal iYieldMode%) As Integer 

Declare Function NIDAQMean Lib "nidex32.dH" (pvBuffer As Any, ByVal lNumPts&, ByVal lType&, dMean#) 
As Integer 

Declare Function NIDAQWaitForKey Lib "nidex32.dll" (ByVal dTimeLimit#) As Integer 
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ABSTRACT 

5 The objectives of the work reported here were to design and integrate a 

communications interface and software procedures (i.e., algorithms) for image 
processing for a Helmet Mounted Display (HMD) image tester. This is a continuation 
of a previous effort entitled "Preliminary Design of an Image Tester for Helmet 
Mounted Display." 

10 The proposed image quality tester consists of hardware (including camera, 

lenses, sensors, and fixtures), and software for image capture and analysis. The 
interface and image processing algorithms are essential components of this system. 
The interface bridges the gap between hardware devices and software applications, 
and thus makes information integration possible. The algorithms process, analyze' 

15 and characterize the test pattern information generated by a Helmet Mounted Display 
(HMD). 

An interface was designed to probe sensor information and 
coordinate/synchronize image capture and analysis events. A set of three limited 
20 switches was utilized to indicate the presence of an HMD, the position of an HMD 
relative to a wide-angle camera, and the 
Block 19 continued 

position of an HMD relative to a narrow-angle camera. These switches are connected 
25 to a data acquisition card (DAQCard-DIO-24) using designed circuitry. The sensor 
on/off states are recorded by the card registers. Software routines (i.e., algorithms) 
were designed and developed to probe the register status, and then use this 
information to coordinate/synchronize image characterization events. In order to 
enhance the flexibility and reduce the complexity of the existing image capture 
30 application, a new image capture module was designed. 

In designing the algorithms, issues such as data collection steps, design specifications, 
and noise generation were taken into consideration. Three HMD units were utilized 
to capture image data. Images with noise — such as displacement and variations in 

35 orientation and focus— were captured. Statistical approaches such as correlation 

coefficients and regression analysis were utilized to probe the relationships between 
performance/image related variables (such as focus) and image gray level variation. 
Knowledge of such relationships enables the use of image variables to verify and/or 
predict control variables such as focus resolution. Image measurement specifications 

40 were developed based on analysis of the collected image data. Algorithms for 
detecting four vertical lines, center point, focus, and boundary are proposed. 
Examples are given to illustrate how the algorithms work and screenshots of images 
before and after image processing are shown. 
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EXAMPLE IMPLEMENTATION B 

(The following is a substantial duplicate of Hsieh, et al., "Preliminary Design of an 
Image Quality Tester For Helmet-Mounted Displays," USAARL Report No. 2000-08 
(November 1999), the content of which is hereby incorporated by reference in its 
5 entirety. 
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and 
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25 
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and 

30 Thomas H. Harding 

Howard H. Beasley 
John S. Martin 

UES, Inc. 

35 

December 1999 

40 
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Notice 

Qualified requesters 

5 Qualified requesters may obtain copies from the Defense Technical Information 
Center (DTIC), Cameron Station, Alexandria, Virginia 22314. Orders will be 
expedited if placed through the librarian or other person designated to request 
documents from DTIC. 

10 Change of address 

Organizations receiving reports from the U.S. Army Aeromedical Research 
Laboratory on automatic mailing lists should confirm correct address when 
corresponding about laboratory reports. 

15 

Disposition 

Destroy this document when it is no longer needed. Do not return it to the originator. 
20 Disclaimer 

The views, opinions, and/or findings contained in this report are those of the author(s) 
and should not be construed as an official Department of the Army position, policy, or 
decision, unless so designated by other official documents. Citation of trade names in 
25 this report does not constitute an official Department of the Army endorsement or 
approval of the use of such commercial items. 
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Helmet-mounted displays (HMDs) are a gateway to the pilot for viewing 
pilotage and fire control imagery. In Army aviation, the AH-64 Apache helicopter 
uses an HMD system known as the Integrated Helmet and Display Sighting System 
(IHADSS). The IHADSS consists of various electronic components and a 
helmet/display system called the Integrated Helmet Unit (IHU). The IHU (Figure Bl) 
includes a helmet, visor housings with visors, miniature cathode ray tube (CRT), and 
helmet display unit (HDU). The HDU serves as an optical relay device which 
conveys the image formed on the CRT through a series of lenses, off a beamsplitter 
(called a combiner), and into the aviator's right eye (Figure B2). The CRT is 1 inch 
in diameter and uses a P-43 phosphor. The combiner is a multilayer dichroic filter 
which is maximized for reflectance at the peak emission of the P-43 phosphor. 

The U.S. Army is currently developing the next generation reconnaissance 
aircraft, the RAH-66 Comanche. This aircraft will incorporate an HMD which will be 
binocular in design. While its final design is still in review, it will basically consist of 
two image sources (either miniature CRTs or liquid crystal displays) with two sets of 
optics, delivering imagery to both eyes. 

See 

Figure Bl. The IHU of the AH-64 IHADSS. 



25 Currently, there is no existing image quality tester for HMD validation in the 

field. To maintain system integrity and readiness, and to provide pilots with 
validated pilotage, navigation, and fire control imagery, there is a need to design and 
construct an image quality testing tool for the HMD. The objective of this study is to 
propose and test a design concept for an image quality tester for HMD subsystems. 

30 The tester can be used as a validation tool to verify settings for regular flight missions 
and for preventive maintenance tasks. The first prototype tester will be designed for 
the AH-64's IHADSS HMD. 

See 

35 Figure B2. The IHADSS HDU. 



Functionality and operating process 

40 The proposed tester will allow pilots and maintenance personnel to validate 

the image quality of an HMD. Basic required characteristics include (1) simple 
design, (2) ease of use, (3) robustness, and (4) accuracy for operations and 
maintenance. The prototype should be small enough to fit into a brief case, which 
would include a lap-top, image capture system, and power supply pack. 

45 

The IHADSS HMD has a monocular 30-degree vertical by 40-degree 
horizontal field-of-view (FOV). Future HMDs most likely will have larger FOVs and 
be binocular in design. HMD corner obscurations are generally permissible and 
symmetrical for the IHADSS, as illustrated in Figure B3. Since hardware changes to 
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the various aircraft electronics will not be allowed, image quality validation must be 
performed using manufacturer built-in test patterns. The built-in test pattern of the 
IHADSS HMD is used as the inspection specification on which the first tester will be 
based. The test pattern shows strips of gray opposed along the vertical center lines. 
Each strip contains 8 to 10 shades of gray, depending on the contrast ratio. Adjacent 
shades have a square root of 2 differential of brightness. Figure B4 is a snapshot of 
the test pattern captured from the IHADSS HMD. For more detailed discussion of 
the HMD test pattern features, see the Honeywell, Inc. study guide (1985) and 
Harding et al. (1995). For testing this test pattern, the inspection features used by the 
image quality tester prototype will include (1) four vertical center lines, (2) one 
horizontal center line, (3) two gray shade patterns (with 8 to 10 shades), and (4) a 
boundary box. 

See See 
Figure B3. Display size. Figure B4. Test pattern the IHADSS HMD. 



Based on the design objectives and inspection procedures, the tester operation 
procedures are as follows: (1) the pilot adjusts the HMD settings and passes the HDU 
to the crew chief; (2) the crew chief inserts the HMD into a fixture; (3) the system 
examines the center and horizontal line features of the test pattern using a narrow- 
angle lens; (4) the system inspects the test pattern for image displacement and/or 
disorientation; (5) the system examines the number of gray-shades, the focus, 
luminance, and boundary lines, using a 42-degree wide-angle lens; and (6) the system 
generates a final report. Figure B5 shows a flow chart for the proposed operation 
procedures. 

See 

Figure B5. Flow chart for HMD prototype tester operation. 



Methodology 

This study involved designing and testing (1) the hardware specification for 
image capture, (2) the test pattern inspection features, (3) the software prototype, and 
finally (4) the hardware prototype. Experiments and statistical analysis tools were 
applied throughout the design process. 



Image capture hardware specifications 

To determine the needed camera and lens specification for test pattern image 
capture, experiments were conducted to verify the sensitivity of a candidate camera. 
The camera and a Photo Research (Appendix A) model 1980 photometer were 
mounted using a reconfigurable optical fixture and bench accessories and were used 
to capture an electronically generated gray shade test pattern. Figure B6 illustrates the 
experimental setup. The luminance of the test pattern image was registered by the 
charged couple device (CCD) camera (and image capture card) and the photometer. 
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Figure B7 shows the locations where data were sampled from the test pattern. These 
data were measured from a fixed position along a horizontal line across the entire test 
pattern. Three measurements were taken from each region. An observation resulting 
from the experiment was that the luminances of the gray shades presented in the test 
5 pattern were not linearly distributed between 0 and 255. The differential of luminance 
for adjacent shades was greater than an approximate square root of 2. A statistical 
analysis was performed on these data. Results indicated that the luminance levels 
measured by the photometer were consistent with data from the camera and image 
capture card up to and including the 7 th gray shade. It can be seen that the CCD 
10 saturated after the 7 th gray shade area. To prevent this, the aperture of the CCD would 
have to be adjusted. If only the first seven gray shades are used in the analysis, 
correlation is 0.98. The table and Figure B8 record the data collected from both 
instruments and the statistical analysis results. 

15 



See 

Figure B6. Experimental setup for camera sensitivity analysis. 

20 



25 See 

Figure B7. Sampling locations on the test pattern. 
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Table . 

Measured data and correlation coefficient from photometer and CCD camera. 



Gray shade 


Photometer luminance readings 


CCD gray level readings 


1 


3.25 


3 32 


3 35 


7 






2 


7 47 


7 51 










3 


17.07 


16 99 


16 99 


65 


65 




4 


30.51 


30.54 


30.43 


99 


99 


99 


5 


48.28 


48.24 


48.12 


146 


146 


146 


6 


71.9 


71.86 


71.81 


194 


194 


194 


7 


98.35 


98.54 


98.67 


227 


227 


227 


8 


127.1 


127.2 


127.3 


230 


230 


230 


9 


157.9 


158.1 


158.0 


235 


235 


235 


10 


187.4 


187.4 


187.1 


240 


240 


240 


11 


221.2 


221.4 


221.2 


242 


242 


242 


12 


200.7 


200.6 


200.6 


237 


237 


237 


Luminance vs gray level (7 shades): Correlation = 0.983886; Fisher's z = 2.406549; 
Probability = 00006 



5 

See 

Figure B8. Plot of photometer and CCD camera data. 



10 In an attempt to capture the test pattern image on the IHADSS fully, several 

different cameras (with standard lenses) were evaluated. However, although the full 
test pattern could be captured, the details of the four vertical center lines could not be 
differentiated. Therefore, a decision was made to use a narrow angle lens to zoom in 
on the center area of the test pattern in order to capture the details of the center lines. 

15 HMDs are also used at night; therefore, the prototype tester—specifically the camera- 
should provide good sensitivity at low luminance levels. First order specifications for 
the required camera were summarized as follows: 

1. Sensitivity: #0.005 lux 
20 2. Focus: To infinity 

3. Resolution: > 768 x 498 pixels 

4. Focal length: ~¥i inch 

5. Iris: Manual 

6. Fields of view: >40 (H) x 30 (V) degrees and -5x3 degrees 
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Test pattern features investigation 

An additional experiment was conducted to investigate various aspects of 
capturing the test pattern. Multiple cameras were used since a single camera that met 
5 all the desired specifications was not available at the time of this study. Aspects of 
interest included the size of the pattern, number of different features, relative 
luminance ratios among features, spatial content of each feature, and number of gray 
shades. The IHADSS HMD was mounted on the top of the optical post, and the post 
was fixed on top of a round optical table controlled by a programmable position table. 

10 The table was driven by a stepping motor with an accuracy of 1 micron (/Am). The 
test pattern image was projected onto a video monitor for observation. Figure B9 
shows the experimental setup. The entire test pattern image from the HMD was 
captured and constructed through a series of mini steps in the horizontal and vertical 
directions. The overall picture was approximately 38 x 29 degrees, which was close 

15 to the specification in the study guide (Honeywell, Inc., 1985). The center line 

occupied approximately 0.5 degree out of 38 degrees. There were two strips with 10 
to 12 gray shades mirrored opposite the center lines. Figure BIO shows the structure 
of the IHADSS test pattern. A series of images were taken to probe the content of 
each gray shade in terms of luminance. Based on the observed information, a series 

20 of image files was constructed and used as an image profile for purposes of the 
software prototype development. Figure B 11 displays this replicated test pattern 
image. 

See 

25 Figure B9. Setup for test pattern measurement. 



See 

Figure BIO. Test pattern design based on measurement results. 



See 

Figure B 1 1 . Replicated test pattern image. 



A similar experiment was conducted to detail the center lines within the test 
pattern. Figure B12 shows the luminance scan measurements for the center lines. The 
four peaks represent the four center lines which are spread out over 0.8 degree from 
valley to valley and 0.4 degree peak to peak. The average peak width is about 0.0969 
degree and the average distance between peaks is about 0.1347 degree. Note: A 
measurement of 1 degree is about 485 ju.m in the object plane. 

Another experiment was conducted to probe the state of the center lines when 
the HMD is in focus and not in focus. Varied focus values of -1 to 1 diopter of CRT 
were applied. Measurements of the four vertical center lines were taken. An 
interesting finding was, when the HMD was in focus, the ratio of luminances between 
bottom to mid-peak (B) and peak to valley (A) was close to 1. However, when the 
setting was not in focus, the B:A ratio was less than one. Figure B13 documents these 
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observations and illustrates the concept. Findings from the above experiments, such 
as measurements, luminance ratios, and the content of each feature within the test 
pattern, were used to create a test pattern image using graphics software. Figure B14 
shows an image of such a test pattern using a 5 X 4 degree lens to focus on the center 
lines of the test pattern. In addition, the ratio of the square root of 2 luminance 
difference was used to design gray shades ranging from 0 to 255 gray levels. 



See 

Figure B12. Measurement of luminance of the center lines. 



See 

Figure B13. Center lines measurement with varied focus. 



To emulate potential human errors in setting up the HMD, a set of parameters 
(including brightness, orientation, spatial adjustment, and contrast) were manipulated 
and the resulting images captured. These images were used as a basis for creating 
new image files. These designed images were used to test the software prototype. 
The experiments were carried out using similar methods. For example, to measure 
the potential displacement of the test pattern, a camera was mounted facing the HMD. 
The test pattern was projected onto a video monitor by means of a personal computer 
(PC). Measurements were taken before and after the spatial adjustments. The 
maximum adjustments in the upward, downward, left and right directions were 3.57, 
2.98, 4.90 and 4.90 degrees, respectively, based on an FOV of 40 x 31 degrees 
(Harding et al., 1995). 



See 

Figure B 14. Designed test pattern with focus on the center lines. 

Software prototype design 

The software prototype was designed to capture, analyze, and interpret the 
image against test pattern features such as the four center lines and number of gray 
shades. Accordingly, the prototype design will require three modules-image 
acquisition, image analysis and interpretation~as well as on-line user help. Figure 
B15 shows the modules involved in the prototype. Visual Basic (VB) was used to 
develop the prototype because of its flexibility in linking and embedding with other 
commercial software and because it was a powerful toolbox for rapidly prototyping a 
complicated window. In the following sections, we describe the functionality of each 
module and how the modules are integrated. Algorithms developed to interpret the 
image follow. Finally, testing and validation of the code is addressed. The source 
code for the program can be found in Appendix B. 
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Image capture module 

The VB Object Linking and Embedding (OLE) capability allows integration 
of other programs. In this case, the image capture graphics program served as an 
object which was linked into the VB main program. The graphics program was 
launched by activating the linked object. Once the object had been activated, the VB 
main program allowed the user to modify, save, or open documents created by the 
graphic program in VB's integrated design environment (IDE). After the user was 
done with the image capture graphics program, control was released to the VB 
environment. The graphics program itself contained three components: the driver 
used to activate the image capture card and digitize the video signal into a graphics 
image format (e.g., bitmap or jpeg); an image processing shell which allowed image 
manipulation (e.g., sharpening and lightening); and an on-line user manual. Figure 
B16 shows the opening screen for the image capture module. Figures B17 and B18 
show image capture and processing subcomponents. 



See 

Figure B15. Opending screen of prototype software. 



See 

Figure B 16. Image capture module. 



See See 
Figure B 17. Image capture. Figure B 18. Imagine processing 

component. component. 

30 Image analysis and interpretation module 

The image analysis and interpretation module (1) detects the presence of key 
features such as center lines within the test pattern, (2) compares selected features 
against the feature specification, and (3) generates findings. VB components were 

35 created to provide these functions and to interface with other modules. A subwindow 
titled "evaluation criteria" was created to analyze and interpret the captured image 
from an HMD. A few created algorithms were coded in VB to perform the analysis. 
Other subwindows, such as a directory box and file list boxes were created to allow 
retrieval of image files for analysis. Finally, an additional subwindow was designed 

40 to display the image currently being analyzed. This module also allows access to 
other modules via a button control. Figure B 19 shows the image analysis and 
interpretation module. 



See 

Figure B19. Image analysis and interpretation module. 
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Algorithm design 

Algorithms were developed to detect various features within the test pattern as 
described earlier. These are described below: 

5 

A. Identify the number of center lines. 

Step 1 . Apply binary image technique to the entire image. 

Step 2. Draw multiple lines across X and/or Y axes. 
10 Step 3. Identify mask with feature of B/W. . . W/B. 

Step 4. Store the intersection points in an array with multiple dimensions. 

Step 5. Construct regression lines based on the points within each dimension. 

Step 6. Develop regression lines to compare the parallel property. 

Step 7. Average the intersection points around the array to obtain the number of 
15 estimated lines. 

Note 1: B = black pixel and W = white pixel. 

Note 2: Use of linear regression analysis would make the linear mode robust and 
insensitive to noise presence. 
20 B. Identify the center point. 

Step 1. Construct a regression line based on all the intercepted points. 

Step 2. Identify the midpoint of an array as a starting point with the feature of 

W/B AW. 

Step 3. Examine neighboring pixels to see if a W/W/W mask exists. 
25 Step 4. If a W/W/W mask exists, stop the procedure; else next step. 

Step 5. Check the distance of neighboring pixels from the regression line using a 3 x 3 
area. 

Step 6. Select the point with the smallest distance from the regression line as the next 
point. 

30 Step 7. Go to step 3. 

C. Identify test pattern orientation and displacement. 

Step 1. Compute a theoretical center as point A. 
35 Step 2. Identify the actual center point (based on part B) as point B. 
Step 3. Compute the distance between point A and B as d. 
Step 4. If d is equal to 0; then the displacement is zero. 
Step 5. Construct lines between a given point with points A and B. 
Step 6. Compute the angle between lines as orientation angle 

40 

D. Identify the number of gray shades within a test pattern. 
Step 1. Use the center point as a starting point. 

Step 2. Pick five points across the center line that are within the boundary of gray 
45 shades. 

Step 3. Compute the average gray level of the five points. 
Step 4. Store it in one dimension of the array. 

Step 5. If the boundary is not reached, move up or down a given distance, and go to 
Step 3; else 
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next. 

Step 6. Use of square root of two differences to determine the number of gray shades. 

E. Identify boundary lines. 

5 

Step 1. Use the center point and boundary ratio to determine the region of the image 
boundary. 

Step 2. Locate a starting point white pixel to use for back tracking the rest of the white 
pixels for each line segment. 

10 

F. Identify the focus setting. 

Step 1. Use line scan technique to record the pixels along the center lines. 
Step 2. Use the B/W/B mask to identify the separation of lines. 
15 Step 3. Compute the ratio of bottom to mid-peak and peak to valley for all four lines. 
Step 4. If the ratio is approximately one, we may conclude that the focus setting is 
good; or else check the focus setting 

Other methods for center point detection exist. However, these were deemed less 
20 appropriate for this application. For instance: 
Alternate approach #1: 

bbbb 

Step 1. Use of the mask of bwwwwwb 
bbbb 

25 

Note: If the orientation of the image is unknown, this method can be time consuming. 

Alternate approach #2: 

30 Step 1. Find the center point of each line. 

Step 2. Use the averaging method to find the center of all the centers. 

Note: This method involves more steps than the proposed one, because you must first 
find the center of each line and there are four lines to be examined. 

35 

Alternate approach #3: 

Step 1. Identify the boundary of the image. 

Step 2. Use the center of gravity method to find the center of the image. 

40 

Figure B20(a-d) shows screens from the image analysis module. Figure B20a 
shows a binary image of the test pattern after the binary image technique had been 
applied to the test pattern captured from the HMD. Figure B20b shows the four 
center lines that were identified from the binary image (Figure B20a). After the 
45 center lines had been identified, the image analysis module identified the center point 
of the image. Figure B20c shows the coordinates (y only shown) of the center point. 
The image analysis module then determined if the image was tilted or not. Figure 
B20d displays the tilt angle of the image. The analysis results are summarized and 
displayed in Figure B21. A primary feature of the image analysis module is to 
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identify features present in the captured test pattern. The "Sober operator," a well 
known edge detection technique, is used to identify the boundaries of the features and, 
thereby, allow the analysis module to determine whether or not the required features 
are present in the captured test pattern image. Figure B22 shows the same image 
5 before and after the Sober operator is applied. 

Testing and validation 

To verify the accuracy of the program, language debugging tools, and split- 
10 half and back tracking strategies were imposed throughout the coding process. The 
program results were compared with the simulation results. For example, to check the 
accuracy of the constructed regression line, the same data points also were analyzed 
and compared with the results obtained from a statistics package and hand calculation. 

15 

See 

Figure B20. Tilted test pattern binary images from image analysis module. 

20 See 

Figure B21. Overall testing results of an HMD. 



See 

25 Figure B22. Tiled test pattern before (left) and after (right) Sober edge detection. 



Hardware package design 

30 A preliminary concept for the hardware package design consists of a 

display/output module, power supply module, and image capture module. The 
display/output module should be designed to display/generate inspection results of an 
HMD test pattern. The power supply module should be designed to provide the 
voltages needed for the cameras and computer. The design also should include a 

35 rechargeable battery pack which will allow the unit to operate in areas without an 
external power supply. The power supply would be required to provide 12- and 9- 
volt outputs for the cameras and computer, respectively. Finally, the image capture 
module must be designed to hold an HMD and two cameras in fixed and contained 
positions, thereby preventing potential noise that may affect the inspection accuracy. 

40 A proposed design is as follows: Two cameras arranged vertically and facing the 
HMD. [Figure B23 shows one method investigated for aligning the CCD image 
capture cameras and the HMD.] An inverted HMD fixture will be the most likely one 
be used in the final concept. The fixture would be mounted with spring return locks 
on the sides and bottom. The spring return locks will lock the HMD in a fixed 

45 position. These locks would prevent the inspection process from continuing if the 
HMD is not positioned correctly. Once the HMD is in the correct position, a 
proximity sensor will be used to trigger the image system to start the image capture 
and interpretation processes. The cover of the image capture module is in the shape 
of an inverted HMD. It is designed to cover the HMD tightly once it is in the correct 
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position, and to eliminate any optical noise from the surrounding environment. To 
enhance the speed of image analysis, an Electronic Programmable Read Only 
Memory (EPROM) chip, custom programmed to load the executable program for 
image analysis, could be used. Figure B24 illustrates a preliminary computer aided 
5 design (CAD) concept of the hardware prototype design. 

Conclusions and future directions 

In this project, a design framework for an image quality tester was proposed 
10 and evaluated. Functionality and requirements of the tester were identified. 

Experiments were conducted to test camera sensitivity and to probe aspects of an 
HMD test pattern using programmable micro-positioning systems and a CCD camera. 
Test pattern specifications were developed based on these observations. A strategy 
for image analysis and interpretation was formed, and algorithms were designed to 
15 verify the test pattern of a given HMD against the specifications. A prototype 

software package was written to inspect the test pattern and verify the effectiveness of 
the algorithms. Finally, a design framework for a concept hardware package was 
proposed. 

20 See 

Figure B23. Investigation of CCD image capture arrangement. 



See 

Figure B24. CAD concept of prototype hardware design. 



To build a brassboard version of a tester, future work must include: (1) 
30 fabrication of the hardware design using inverse casting techniques, (2) integration of 
software and hardware components for a prototype design, (3) field testing of the 
prototype, (4) incorporation of learning algorithms to increase inspection accuracy, 
and (5) expansion of functionality from validation to on-line real time interactive 
adjusting and self-tuning based on a given environmental scenario. From the 
35 maintenance perspective, the work can be expanded to self-diagnosis and preventative 
maintenance (such as life-time prediction). 
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List of manufacturers . 

5 Photo Research 

3000 North Hollywood Way 
Burbank, CA 91505 
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ABSTRACT 

Helmet-mounted displays (HMD's) provide essential pilotage and fire control 
imagery information for pilots. However, image quality testers for HMD field 
5 performance validation do not currently exist. This research employed techniques 
from imaging analysis and interpretation, and computer-aided deign/computer-aided 
manufacturing (CAD/CAM) to investigate a preliminary design for a portable HMD 
image quality tester. 

10 For this study, a charge coupled device (CCD) camera and lens were selected. 

Hardware characteristics such as viewing angles in horizontal and vertical positions, 
dynamic working range at day and night, pixel resolution, focal length, and aperture 
ratio were evaluated with regard to HMD functionality. Experiments to evaluate 
camera sensitivity and test pattern merits were conducted using a programmable 

15 micro-positioning system, CCD camera, optical fixtures and benches. Next, the 
relative ratio among features within the image profile was established and an ideal 
image profile and evaluation criteria were established based on the experimental 
results. Third, image processing algorithms and techniques, such as edge detection, 
were developed and applied in test pattern feature detection. A software prototype 

20 including modules for image capture, image analysis and interpretation, and user 
manuals was developed. Finally, a concept hardware package design is proposed. 
This design incorporates a notebook computer with flat panel display to interface with 
the camera and software prototype; and fixtures for the HMD, camera, computer, and 
power supply. This design will allow the tester to be used in the field. 
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The foregoing described embodiments depict different components contained 
within, or connected with, different other components. It is to be understood that such 
depicted architectures are merely exemplary, and that in fact many other architectures 
can be implemented which achieve the same functionality. In a conceptual sense, any 
arrangement of components to achieve the same functionality is effectively 
"associated" such that the desired functionality is achieved. Hence, any two 
components herein combined to achieve a particular functionality can be seen as 
"associated with" each other such that the desired functionality is achieved, 
irrespective of architectures or intermedial components. Likewise, any two 
components so associated can also be viewed as being "operably connected", or 
"operably coupled", to each other to achieve the desired functionality. 

While particular embodiments of the present invention have been shown and 
described, it will be obvious to those skilled in the art that, based upon the teachings 
herein, changes and modifications may be made without departing from this invention 
and its broader aspects and, therefore, the appended claims are to encompass within 
their scope all such changes and modifications as are within the true spirit and scope 
of this invention. Furthermore, it is to be understood that the invention is solely 
defined by the appended claims. It will be understood by those within the art that if a 
specific number of an introduced claim element is intended, such an intent will be 
explicitly recited in the claim, and in the absence of such recitation no such intent is 
present. For example, as an aid to understanding, the following appended claims may 
contain usage of the introductory phrases "at least one" and "one or more" to 
introduce claim elements. However, the use of such phrases should not be construed 
to imply that the introduction of a claim element by the indefinite articles "a" or "an" 
limits any particular claim containing such introduced claim element to inventions 
containing only one such element, even when the same claim includes the 
introductory phrases "one or more" or "at least one" and indefinite articles such as "a" 
or "an"; the same holds true for the use of definite articles used to introduce claim 
elements. In addition, even if a specific number of an introduced claim element is 
explicitly recited, those skilled in the art will recognize that such recitation should 
typically be interpreted to mean at least the recited number (e.g., the bare recitation of 
"two elements," without other modifiers, typically means at least two elements, or 
two or more elements). 
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WHAT IS CLAIMED IS: 

1 1. A method comprising: 

2 capturing an image actually displayed via a display sighting system; 

3 computing at least one difference between the captured image and a recalled 

4 representation of the image theoretically displayed via the display 

5 sighting system; and 

6 presenting the computed at least one difference via a visual display device. 

1 2. The method of Claim 1, wherein said computing at least one difference 

2 between the captured image and a recalled representation of the image theoretically 

3 displayed via the display sighting system further comprises: 

4 computing at least one angular difference between an angular orientation of 

5 the captured image and the recalled representation of the image 

6 theoretically displayed via the display sighting system; 

7 computing at least one centering difference between a center point of the 

8 captured image and the recalled representation of the image 

9 theoretically displayed via the display sighting system; or 

10 computing at least one focus difference between an optical power of the 

1 1 captured image and the recalled representation of the image 

12 theoretically displayed via the display sighting system. 

1 3. The method of Claim 2, wherein the recalled representation of the 

2 image theoretically displayed via the display sighting system comprises a test pattern 

3 having at least one vertical line. 

1 4. The method of Claim 2, wherein the recalled representation of the 

2 image theoretically displayed via the display sighting system comprises a test pattern 

3 having at least one horizontal line. 
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1 5. The method of Claim 2, wherein said presenting the computed at least 

2 one difference via a visual display device further comprises: 

3 presenting the at least one angular difference between an angular orientation 

4 of the captured image and the recalled representation of the image 

5 theoretically displayed via the display sighting system; 

6 presenting the at least one centering difference between a center point of the 

7 captured image and the recalled representation of the image 

8 theoretically displayed via the display sighting system; or 

9 presenting the at least one focus difference between an optical power of the 

10 captured image and the recalled representation of the image 

1 1 theoretically displayed via the display sighting system. 

1 6. The method of Claim 1 , wherein said computing at least one difference 

2 between the captured image and a recalled representation of the image theoretically 

3 displayed via the display sighting system further comprises: 

4 computing at least one gray-shades-displayed difference between gray shades 

5 of the captured image and gray shades of the recalled representation of 

6 the image theoretically displayed via the display sighting system; 

7 computing at least one field-of-view difference indicated by a difference 

8 between a boundary location of the captured image and the recalled 

9 representation of the image theoretically displayed via the display 
1° sighting system; or 

1 1 computing at least one predicted focus magnitude indicated by a difference 

12 between brightness, contrast, and gray level of a captured image and 

1 3 the recalled representation of the image theoretically displayed via the 

14 display sighting system. 

1 7. The method of Claim 6, wherein the recalled representation of the 

2 image theoretically displayed via the display sighting system comprises a test pattern 

3 having at least two gray shades. 
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1 8. The method of Claim 6, wherein said presenting the computed at least 

2 one difference via a visual display device further comprises: 

3 presenting the at least one gray-shades-displayed difference between gray 

4 shades of the captured image and gray shades of the recalled 

5 representation of the image theoretically displayed via the display 

6 sighting system; 

7 presenting the at least one field-of-view difference indicated by a difference 

8 between a boundary location of the captured image and the recalled 

9 representation of the image theoretically displayed via the display 

10 sighting system; or 

1 1 presenting the at least one predicted focus magnitude indicated by a difference 

12 between brightness, contrast, and gray level of a captured image and 

13 the recalled representation of the image theoretically displayed via the 

14 display sighting system. 

1 9. The method of Claim 1, wherein said capturing an image actually 

2 displayed via a display sighting system further comprises: 

3 capturing the image via a camera. 

1 10. The method of Claim 9, wherein said capturing the image via a camera 

2 further c ompri ses : 

3 capturing the image via a data acquisition card interposed between a narrow- 

4 angle camera and a portable computer system; or 

5 capturing the image via a data acquisition card interposed between a wide- 

6 angle camera and the portable computer system. 

1 11. A system comprising: 

2 circuitry for capturing an image actually displayed via a display sighting 

3 system, wherein said circuitry for capturing an image includes one or 

4 more electrical circuits selected from the group including but not 

5 limited to electrical circuits having at least one discrete electrical 

6 circuit, electrical circuits having at least one integrated circuit, 
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7 electrical circuits having at least one application specific integrated 

8 circuit, and electrical circuits providing at least one general purpose 

9 computing device configurable by a computer program; 

10 circuitry for computing at least one difference between the captured image and 

1 1 a recalled representation of the image theoretically displayed via the 

12 display sighting system, wherein said circuitry for computing includes 

13 one or more electrical circuits selected from the group including but 

14 not limited to electrical circuits having at least one discrete electrical 

15 circuit, electrical circuits having at least one integrated circuit, 

16 electrical circuits having at least one application specific integrated 

17 circuit, and electrical circuits providing at least one general purpose 

18 computing device configurable by a computer program; and 

19 circuitry for presenting the computed at least one difference via a visual 

20 display device, wherein said circuitry for presenting includes one or 

21 more electrical circuits selected from the group including but not 

22 limited to electrical circuits having at least one discrete electrical 

23 circuit, electrical circuits having at least one integrated circuit, 

24 electrical circuits having at least one application specific integrated 

25 circuit, and electrical circuits providing at least one general purpose 

2 6 computing device configurable by a computer program. 

1 12. The system of Claim 11, wherein said circuitry for computing at least 

2 one difference between the captured image and a recalled representation of the image 

3 theoretically displayed via the display sighting system further comprises: 

4 circuitry for computing at least one angular difference between an angular 

5 orientation of the captured image and the recalled representation of the 

6 image theoretically displayed via the display sighting system; 

7 circuitry for computing at least one centering difference between a center 

8 point of the captured image and the recalled representation of the 

9 image theoretically displayed via the display sighting system; or 

10 circuitry for computing at least one focus difference between an optical power 

1 1 of the captured image and the recalled representation of the image 

12 theoretically displayed via the display sighting system. 
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1 13. The system of Claim 12, wherein the recalled representation of the 

2 image theoretically displayed via the display sighting system comprises a test pattern 

3 having at least one vertical line. 

1 14. The system of Claim 12, wherein the recalled representation of the 

2 image theoretically displayed via the display sighting system comprises a test pattern 

3 having at least one horizontal line. 

1 15. The system of Claim 12, wherein said circuitry for presenting the 

2 computed at least one difference via a visual display device further comprises: 

3 circuitry for presenting the at least one angular difference between an angular 

4 orientation of the captured image and the recalled representation of the 

5 image theoretically displayed via the display sighting system; 

6 circuitry for presenting the at least one centering difference between a center 

7 point of the captured image and the recalled representation of the 

8 image theoretically displayed via the display sighting system; or 

9 circuitry for presenting the at least one focus difference between an optical 

10 power of the captured image and the recalled representation of the 

1 1 image theoretically displayed via the display sighting system. 

1 16. The system of Claim 1 1, wherein said circuitry for computing at least 

2 one difference between the captured image and a recalled representation of the image 

3 theoretically displayed via the display sighting system further comprises: 

4 circuitry for computing at least one gray-shades-displayed difference between 

5 gray shades of the captured image and gray shades of the recalled 

6 representation of the image theoretically displayed via the display 

7 sighting system; 

8 circuitry for computing at least one field-of-view difference indicated by a 

9 difference between a boundary location of the captured image and the 

10 recalled representation of the image theoretically displayed via the 

1 1 display sighting system; or 
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12 circuitry for computing at least one predicted focus magnitude indicated by a 

13 difference between brightness, contrast, and gray level of a captured 

1 4 image and the recalled representation of the image theoretically 

1 5 displayed via the display sighting system. 

1 17. The system of Claim 1 6, wherein the recalled representation of the 

2 image theoretically displayed via the display sighting system comprises a test pattern 

3 having at least two gray shades. 

1 18. The system of Claim 16, wherein said circuitry for presenting the 

2 computed at least one difference via a visual display device further comprises: 

3 circuitry for presenting the at least one gray-shades-displayed difference 

4 between gray shades of the captured image and gray shades of the 

5 recalled representation of the image theoretically displayed via the 

6 display sighting system; 

7 circuitry for presenting the at least one field-of-view difference indicated by a 

8 difference between a boundary location of the captured image and the 

9 recalled representation of the image theoretically displayed via the 
1° display sighting system; or 

1 1 circuitry for presenting the at least one predicted focus magnitude indicated by 

12 a difference between brightness, contrast, and gray level of a captured 

13 image and the recalled representation of the image theoretically 

14 displayed via the display sighting system. 

1 19. The system of Claim 1 1 , wherein said circuitry for capturing an image 

2 actually displayed via a display sighting system further comprises: 

3 circuitry for capturing the image via a camera. 

1 20. The system of Claim 19, wherein said circuitry for capturing the image 

2 via a camera further comprises: 

3 circuitry for capturing the image via a data acquisition card interposed 

4 between a narrow-angle camera and a portable computer system; or 
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5 circuitry for capturing the image via a data acquisition card interposed 

6 between a wide-angle camera and the portable computer system. 

1 21. An image capturing device comprising: 

2 a Helmet Display Unit (HDU) holding fixture; and 

3 at least one camera mounted proximate to the HDU holding fixture. 

1 22. The image capturing device of Claim 2 1 , wherein the Helmet Display 

2 Unit (HDU) holding fixture comprises: 

3 the Helmet Display Unit (HDU) holding fixture movable between at least two 

4 positions. 

1 23. The image capturing device of Claim 21, wherein the Helmet Display 

2 Unit (HDU) holding fixture comprises: 

3 the Helmet Display Unit (HDU) holding fixture is attached to a lever-spring 

4 assembly. 

1 24. The image capturing device of Claim 21, wherein said at least one 

2 camera mounted proximate to the HDU holding fixture comprises: 

3 at least one wide-angle and at least one narrow-angle camera. 
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IMAGE QUALITY TESTER 

Clarence E. Rash 

Sheng-Jen Hsieh 
Thomas H. Harding 
Howard H. Beasley 

John S. Martin 
Ronald W. Reynolds 

Robert M. Dillard 

ABSTRACT OF THE DISCLOSURE 

A method including but not limited to capturing an image actually displayed 
via a display sighting system; computing at least one difference between the captured 
image and a recalled representation of the image theoretically displayed via the 
display sighting system; and presenting the computed at least one difference via a 
visual display device. In various implementations, circuitry is used to effect the 
foregoing-described method; the circuitry can be virtually any combination of 
hardware, software, and/or firmware configured to effect the foregoing-described 
method depending upon the design choices of the system designer. 



689433 vl 



- 114- 



^ 0 o 




capture an image 
of IHADSS test - 
pattern 



compute at least one difference between the captured image of I HA DSS test 

pattern and a recalled representation of the image of IHADSS t est pattern 
theoretically displayed via the display sighting system; that is, the re is stored 
in memory (e.g., computer memory) a representation of how the i mage of 

IHADSS test pattern would or should appear if the IHADSS is both 
functioning correctly and set up properly (e.g., by a pilot), and it is such a 
representation that is recalled 



present the computed at least one difference via a visual 
display device (e.g., via a portable computer sys tern display) 



<jr 508 Fig. 5 

(siop) — ^ 



r 



capture an image 
of IHADSS test 
pattern 



^ompute at least one difference between the captured image of IHADSS tesl pattern and a recalled representation of the image of I HADSS test pattern 

theoretically displayed via the display sighting system; that is, there is storejl in memory (e.g., computer memory) a representation o f how the image of 

IHADSS test pattern would or should appear if the IHADSS is both functioning correctly and set up properly (e.g., by a pilot), and it is s uch a representation 

that is recalled 



compute at least one angular 
difference between an angular 
orientation of the captured image 
and the recalled representation of 
the image theoretically displayed vie 
the display sighting system 



compute at least one centering 
difference between a center point 
of the captured image and the 
recalled representation of the 
image theoretically displayed via 
the display sighting system 



compute at least one focus 
difference between an optical 
power of the captured image and 
the recalled representation of the 
image theoretically displayed v'k 

the display sighting system 



Fig. 6A 



Where center of test pattern should 
appear if IHADSS functioning 
substantially optimally 



Where center of captured image 
appears; note captured image appears 
skewed relative to orientation of 
theoretic image 




x-offset between— 
theoretic and actual 
test pattern center 




capture an image 
of IHADSS test - 
pattern 



compute at least one difference between the captured image of I HA DSS test 

pattern and a recalled representation of the image of IHADSS t est pattern 
theoretically displayed via the display sighting system; that is, the re is stored 
in memory (e.g., computer memory) a representation of how the i mage of 

IHADSS test pattern would or should appear if the IHADSS i s both 
functioning correctly and set up property (e.g., by a pilot), and it is such a 
representation that is recalled 



present the computed at least one difference via a visual dijsp ay device (e.g., via a portable c omputer system display) 



present the at least one angular d ifference 
between an angular orientation of the 
captured image and the recalled 
representation of the image theoretically 
displayed via the display sighting system 
(e.g., the computed quantity of method step 
600) 



present the at least one centering 
difference between a center point of 
the captured image and the recalled 

representation of the image 
theoretically displayed via the display 
sighting system (e.g., the com puted 
quantity of method step 602) 



present the at least one focus di fference 
between an optical power of the captured 
image and the recalled representation of 
the image theoretically displayed via the 

display sighting system (e.g. , the 
computed quantity of method step 604) 



Jr 508 
(Stop) ^ 



Fig. 7 



capture an image 
oflHADSStest - 
pattern 



compute at least one difference between the captured image of IHADSS'te^t pattern and a recalled representation of the image of I HADSS test pattern 
theoretically displayed via the display sighting system; that is, there is storejJ in memory (e.g., computer memory) a representation o f how the image of 
IHADSS test pattern would or should appear if the IHADSS is both functioning correctly and set up properly (e.g., by a pilot), and it is s uch a representation 

that is cecal led 



compute at least one gray-shades- 
displayed difference between gray 
shades of the captured image and 
gray shades of the recalled 
representation of the image 
theoretically displayed via the 
display sighting system 



compute at least one field-of-view 
difference indicated by a 
difference between a boundary 
location of the captured image 
and the recalled representation of 
the image theoretically displayed 
via the display sighting system 



804 

compute at least one image 
quality figure of merit indicated 

by a difference between 
brightness, contrast, and gray 
level of a captured image and 
the recalled representation of the 
image theoretically displayed via 
the display sighting system 



present the computed at least one difference via a visual 
display device (e.g., via a portable computer sys tern display) 




capture an image 
of IHADSS test - 
pattern 



compute at least one difference between the captured image of IHA DSS test 

pattern and a recalled representation of the image of IHADSS test pattern 
theoretically displayed via the display sighting system; that is, the re is stored 
in memory (e.g., computer memory) a representation of how the i mage of 

IHADSS test pattern would or should appear if the IHADSS is both 
functioning correctly and set up properly (e.g., by a pilot), and it is such a 
representation that is recalled 



present the computed at least one difference via a visual dijsplay device (e.g., via a portable c omputer system display) 



present the at least one gray -shades- 
displayed difference between gray shades 
of the captured image and gray sh ades of 
the recalled representation of the image 
theoretically displayed via the display 
sighting system (e.g., the computed qu antity 
of method step 800) 



present the at least one field -of-view 
difference indicated by a difference 
between a boundary location of the 
captured image and the recalled 
representation of the image 
theoretically displayed via the display 
sighting system (e.g., the com puted 
quantity of method step 802) 



present the at least one image quality 
figure of merit indicated by a difference 
between brightness, contrast, and gray 
level of a captured image and the 
recalled representation of the image 
theoretically displayed via the display 
sighting system (e.g., the computed 
quantity of method step 804) 



Stop J Fig. 9 




FIG 10 




Figure Al. The IHADSS 




Figure A2. The IHADSS HDU. 



40 Degrees 




30 Degrees 



Figure A3. Display size. 
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Figure A9. Schematic diagram of proposed design. 
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Figure A17. Image after binary processing. 
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Figure B22. Tilted test pattern before (left) and after (right) Sober edge detection. 
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DECLARATION FOR PATENT APPLICATION 
AND POWER OF ATTORNEY 



As a below named inventor, I hereby declare that: 



My residence, post office address and citizenship are as stated below adjacent to my name. 

I believe I am the original, first and sole inventor (if only one name is listed below) or an original, 
first and joint inventor (if plural names are listed below) of subject matter (process, machine, 
manufacture, or composition of matter, or an improvement thereof) which is claimed and for which a 
patent is sought by way of the application entitled 

Image Quality Tester 

which (check) is attached hereto. 

f~l and is amended by the Preliminary Amendment attached hereto. 
["1 was filed on as Application Serial No. 
and was amended on (if applicable). 



I hereby state that I have reviewed and understand the contents of the above identified specification, 
including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information, which is material to patentability as defined in 
Title 37, Code of Federal Regulations, § 1.56. 

I hereby claim foreign priority benefits under Title 35, United States Code, § 1 19(a)-(d) of any foreign 
application(s) for patent or inventor's certificate or any PCT international application(s) designating at 
least one country other than the United States of America listed below and have also identified below 
any foreign application(s) for patent or inventor's certificate or any PCT international application(s) 
designating at least one country other than the United States of America filed by me on the same 
subject matter having a filing date before that of the application(s) of which priority is claimed: 



Prior Foreign Application(s) 


Priority Claimed 


Number 


Country 


Day/Month/Year Filed 


Yes 


No 


N/A 






□ 


□ 



I hereby claim the benefit under Title 35, United States Code, § 119(e) of any United States 
provisional application(s) listed below: 



Provisional Application Number 


Filing Date 


Not yet assigned 


October 11,2000 



I hereby claim the benefit under Title 35, United States Code, § 120 of any United States 
application(s) or PCT international application(s) designating the United States of America listed 
below and, insofar as the subject matter of each of the claims of this application is not disclosed in the 
prior application(s) in the manner provided by the first paragraph of Title 35, United States Code, 
§ 1 12, 1 acknowledge the duty to disclose information, which is material to patentability as defined in 
Title 37, Code of Federal Regulations, § 1.56, which became available between the filing date of the 
prior application(s) and the national or PCT international filing date of this application: 



Application Serial No. 


Filing Date 


Status (patented, pending, abandoned) 


N/A 
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the United States Patent and Trademark Office connected therewith: 



Custer Number 2«51 



Please address all correspondence and telephone calls to: 

Dale R. Cook 
SKJERVEN MORRILL MacPHERSON LLP 

25 Metro Drive, Suite 700 
San Jose, California 95110-1349 

Telephone: 408-453-9200 
Facsimile: 408-453-7979 

I declare that all statements made herein of my own knowledge are true, all statements made herein on 
information and belief are believed to be true, and all statements made herein are made with the 
knowledge that whoever, in any matter within the jurisdiction of the Patent and Trademark Office, 
knowingly and willfully falsifies, conceals, or covers up by any trick, scheme, or device a material 
fact, or makes any false, fictitious or fraudulent statements or representations, or makes or uses any 
false writing or document knowing the same to contain any false, fictitious or fraudulent statement or 
entry, shall be subject to the penalties including fine or imprisonment or both as set forth under 18 
U.S.C. 1001, and that violations of this paragraph may jeopardize the validity of the application or 
this document, or the validity or enforceability of any patent, trademark registration, or certificate 
resulting therefrom. 

Full name of sole (or first joint) inventor: Clarence E. Rash 
Inventor' s Signature: Date: 



Residence: Enterprise, Alabama 

Post Office Address: 1 10 Victoria Drive Citizenship: United States 

Enterprise, Alabama 36330 
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Enterprise, Alabama 36330 
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